以太幣交易所 以太幣交易所
Ctrl+D 以太幣交易所
ads
首頁 > Ethereum > Info

硬分叉與軟分叉——區塊鏈版本更新的必經之路_區塊鏈

Author:

Time:1900/1/1 0:00:00

區塊鏈是一個存在于互連網中的大型分散式系統,存在于每一個網路參與者的電腦中。

換句話說,一但區塊鏈要進行版本更新或系統修改,所有網路參與都必須下載并運行新版本的區塊鏈客戶端,區塊鏈系統才能完成版本更新。

然而,分布式共識系統升級時困難的地方在于,很難要求網路參與者在同一時間完成更新,只要有參與者沒有即時更新客戶端,網路上就會存在不同版本的區塊鏈,換句話說,區塊鏈會出現分叉。

區塊鏈更新產生的共識問題

因此,區塊鏈進行更新時,必須協調好所有的系統參與者,否則可能會影響到區塊鏈系統的安全性。

另一個分布式共識系統升級困難的地方在于,必須讓所有網路參與者達成共識。

如果只有一部分礦工同意更新,另外一部分舊礦工不同意更新,礦工之間便會產生共識問題。

而區塊鏈更新時的共識問題大致上會有以下四種可能:

香港金管局:數碼港元先導計劃啟動,首輪試驗包括交易結算和代幣化資產結算:金色財經報道,香港金融管理局今日宣布啟動數碼港元先導計劃。16間來自金融、支付和科技界的入選公司將于今年內進行首輪試驗,深入研究數碼港元在六個范疇的潛在用例,包括全面支付、可編程支付、離線支付、代幣化存款、第三代互聯網(Web3)交易結算和代幣化資產結算。

其中,匯豐、VISA等16家入選公司將于今年內進行首輪試驗。[2023/5/18 15:11:22]

1)新礦工接受舊礦工挖出的區塊

2)新礦工不接受舊礦工挖出的區塊

3)舊礦工接受新礦工挖出的區塊

4)舊礦工不接受新礦工挖出的區塊

硬分叉

新礦工產生的區塊可以兼容舊礦工產出的區塊,而舊礦工產生的區塊無法兼容新礦工產出的區塊。

Mt.Gox債權人登記截止日期從1月10日推遲至3月10日:1月6日消息,Mt.Gox債權人登記截止日期從1月10日推遲至3月10日(日本時間)。

此前2022年10月份,Mt.Gox修復計劃索賠系統發布一項新功能,允許債權人選擇還款方式,并在線上索賠申報系統上登記收款人信息,截止日期為2023年1月10日。[2023/1/6 10:58:28]

硬分叉與軟分叉-硬分叉

當系統中出現了新版本的更新,并且和前版本不能兼容,舊礦工無法接受新礦工挖出的全部或部分區塊,區塊鏈就會出現硬分叉。

以比特幣為例,若更改協議的重要參數,例如區塊大小、挖礦題目的難度或出塊速度等,這些規則中的任何一個的更改都可能導致新區塊無法被前版本的共識規則接受。

例如,如果更新后,區塊容量限制從1MB增加到4MB,則運行新版本的礦工將接受4MB的區塊,但運行舊版本的礦工則會拒絕該塊。

NFT周交易量創新低,連續13周低于15.3萬枚ETH:8月18日消息,據Nansen數據,NFT周交易量(8月9日至15日)達76,637枚ETH,創歷史新低,已連續13周低于15.3萬枚ETH。目前,Bend DAO NFT抵押品總計價值31,244.99枚ETH(約5762萬美元),有14枚BAYC健康因子低于1.1。[2022/8/18 12:33:45]

1

社群達成共識

硬分叉與軟分叉-達成共識

在新礦工占有大部分算力的情況下,舊礦工有兩個選擇,第一種就是接受更新并升級客戶端軟體,這個情況意味著社群對版本更新達成共識,區塊鏈可以安全且順利完成更新。

2

社群無法達成共識

硬分叉與軟分叉-無法達成共識

如果就礦工堅持維護舊版本的系統,那區塊鏈將因此分裂為兩條鏈。(在這個情況下,新礦工與舊礦工已經無法達成共識了,即便接受更新的新礦工算力>51%,舊礦工依然不愿意接受新版本,因此不適用“最長鏈共識”。)

Coinbase前產品經理Ishan Wahi對加密貨幣內幕交易指控不認罪:金色財經消息,Coinbase前產品經理Ishan Wahi對加密貨幣內幕交易指控不認罪。Ishan Wahi被指控與他的兄弟Nikhil Wahi和Sameer Ramani分享交易所代幣上市信息,美國證券交易委員會(SEC)也對其提出指控,并在訴訟程序中將Coinbase平臺的九個代幣稱為證券。據司法部稱,Ishan Wahi泄露了至少14種不同代幣的上市信息,被告通過該計劃賺取了150萬美元。[2022/8/4 2:57:41]

若大部分的人都選擇更新,那新版本的算力勢必比較強,剩下的就看舊版本的算力夠不夠支持維護一條鏈的安全,倘若還是有一定數量的礦工堅持維護舊版本,那區塊鏈就會分裂成兩條鏈。

當區塊鏈分裂為兩條鏈,且在有各自的礦工維護各自的鏈的情況下,就會產生兩種不一樣的幣,這就是所謂的“分叉幣”。

例如比特幣社群在2017年的擴容方案理念產生分歧,無法達成共識導致硬分叉,比特幣現金(BitcoinCash)因此誕生。

對用戶而言,這種社群分裂的硬分叉,最有感的就是可以領分叉幣,舉個例子,分叉前你在錢包有“1BTC”,分叉后你將擁有“1BTC+1BCH”。

在沒有得到所有生態中的參與者同意的情況下,硬分叉有很大的風險,很容易導致該區塊鏈的生態系分裂、算力分裂以及陷入重放攻擊的危險中。

所以這是一種極具爭議和危險的區塊鏈升級技術,因此區塊鏈社群對于硬分叉非常謹慎。

軟分叉

在新礦工算力>51%時,新礦工產生的區塊不能兼容舊礦工產出的區塊,舊礦工可以兼容新礦工產出的區塊。

硬分叉與軟分叉-軟分叉

如果以“更嚴格的規則”進行更新,實現協議修改或添加不影響結構的功能時,則舊礦工將接受新礦工所產的區塊;

相反的,由于新礦工所認定的協議較嚴格,新礦工將會拒絕舊礦工所產的區塊,此時舊礦工在正常情況下,會選擇升級,否則其所產的區塊會無法被新礦工接受,無法獲得挖礦獎勵。

遇到例如意識形態或開發觀點不同等特殊情況時,舊礦工仍然有可能會選擇不接受新礦工產出的區塊,繼續維護舊版本的鏈,進而導致硬分叉甚至分裂。

以比特幣為例,理想的情況是,舊礦工會意識到他們的區塊被拒絕了,便會選擇升級。

隨著越來越多的礦工升級,這將進一步孤立舊版本的區塊,在利益的驅使下,會誘使更多舊礦工升級,于是,系統便能以較溫和的方式完成更新。

例如,社區決定將塊大小從目前的1MB限制減少到0.5MB。

占多數的新礦工會拒絕舊礦工產出的1MB區塊,并選擇其他礦工產出的符合條件的區塊。

軟分叉的更新時常發生。

最初比特幣沒有區塊大小的限制,是在之后透過軟分叉引入1MB的限制,還通過軟分叉成功添加了pay-to-script-hash函數,該函數在不改變結構的情況下增強了代碼。

這種類型的更新通常只需要大多數礦工進行升級,其他礦工便會隨之升級,這使得它更可行,破壞性更小。

鏈金研究員總結

軟分叉與硬分叉相比,軟分叉的過程中,在正常情況下,只會存在一條鏈,沒有分成兩條鏈的風險,且軟分叉不要求所有礦工同一時間升級,而是以較溫和的方式逐步升級,不影響軟分叉過程中的系統穩定性和有效性。

然而兩者并沒有孰優孰劣之分,而是適用性的問題,假如進行大規模的區塊鏈更新,勢必會牽涉到不被舊協議接受的規則。

即便我們都知道軟分叉比硬分叉來的安全,還是只能選擇以硬分叉進行區塊鏈升級。

不過也不需要把硬分叉想得太過可怕,因為只要全網礦工對升級有相同的共識,就不會分叉成兩條區塊鏈,影響到安全性。

總歸一句,對區塊鏈升級而言,重要的不是硬分叉還是軟分叉,而是礦工與礦工之間的共識是否一致,這部分稱之為“區塊鏈治理”。

若共識處理不好則容易導致革命,這也是為什么區塊鏈的升級相較傳統軟體還要來的困難。

投資有風險,本文觀點和意見僅代表作者本人,并不構成任何建議。

Tags:區塊鏈比特幣SHAETH區塊鏈用大白話解釋特比特幣價格DEXSHAREeth官網查詢

Ethereum
金色觀察 | 專注于數據可用層 一文讀懂新公鏈Celestia_STI

你可能已經閱讀了許多區塊鏈正在研究從單體設計到模塊化設計的演變。你可能沒有聽說過Celestia,這是第一個以模塊化架構設計的區塊鏈.

1900/1/1 0:00:00
為何說 Tornado Cash 是隱私交易的天堂?_TOR

作者:代觀 01前言 互聯網自1974年TCP/IP協議誕生至今,已經快50年了。如今監管制度日趨嚴格,互聯網基礎設施也日益完備,曾被互聯網廣為宣傳的匿名性已不堪一擊.

1900/1/1 0:00:00
細讀Celestia的優勢,它真的能引領模塊化區塊鏈的未來嗎?_區塊鏈

撰文:RainandCoffee編譯:0xbread,TechFlow模塊化協議VS模塊化軟件在我們開始研究模塊化應用程序特定的區塊鏈之前,首先要對模塊化協議,和模塊化軟件進行區分.

1900/1/1 0:00:00
觀點:為什么我相信GameFi依然會引領下一波浪潮?_EFI

撰文|RaymondChng編譯|0xbread,TechFlow下一個板塊輪動將會是Gamefi,現在依然還處于這個領域的早期階段.

1900/1/1 0:00:00
DeFi 世界的樂高Dego Finance就這樣“塌了”嗎?_ETH

2月10日,成都鏈安鏈必應-區塊鏈安全態勢感知平臺輿情監測顯示,DeFi應用DegoFinance遭到黑客攻擊,UniSwap和PancakeSwap上的DEGO流動性已被耗盡.

1900/1/1 0:00:00
避坑指南:垃圾NFT項目的十三個特性_NFT

原文來自:bankless作者:WilliamM.Peaster 編譯:隔夜的粥 當談到優秀的NFT項目時,我們將才華橫溢的創造者、創新機制以及充滿活力的社區視為重要因素.

1900/1/1 0:00:00
ads