以太坊價格 以太坊價格
Ctrl+D 以太坊價格
ads

POLY:Polkadot共識第3部分:BABE-ODAILY

Author:

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

這是我們的Polkadot共識系列文章的第3部分。有關簡介,請參見第1部分,有關GRANDPA的討論,請參見第2部分。

區塊鏈擴展的盲分配是一種區塊生產引擎,其靈感來自另一個權益證明協議OuroborosPraos。BABE可以單獨使用因為提供確定性概率,也可以與GRANDPA這樣的終端工具結合使用。

BABE是基于插槽的算法。它把時間分成幾個時間段,每個時間段都分成多個時間間隙。在Polkadot中,我們目標區塊的時間間隙時長為六秒鐘。BABE將選擇一個作者在每個插槽中創建一個區塊。

Polyhedra旗下跨鏈橋zkBridge已集成至Polygon:5月29日消息,ZK基礎設施初創公司Polyhedra Network宣布旗下跨鏈橋zkBridge已集成至Polygon網絡,用戶可以在Polygon上使用由zkBridge提供支持的互操作性。[2023/5/29 9:48:53]

BABE中的時間分成幾個時段,每個時段是一組插槽。

將創建者分配到這些插槽的一種方法就是簡單地輪流使用。然而在這種循環模式下,對手始終知道下一位創建者是誰,并可以利用該信息來調整攻擊。理想情況是在他或她做出證明之前,沒人知道創建是誰。

每個槽位可以有主要創建者和次要創建者。主插槽的負責權限是隨機分配的。但是由于該功能是隨機的,所以有時會有一些沒有主要負責人的插槽。為了確保區塊時間的一致性,BABE使用循環系統來安排次級插槽負責人。

派盾:Polynomial Protocol存款合約或存在漏洞:12月12日消息,據派盾監測,據多位用戶反饋,基于Optimism的期權流動性聚合協議Polynomial Protocol或存在漏洞,提醒用戶盡快取消該合約授權。[2022/12/12 21:39:21]

主要插槽

主要插槽的領導權授予是基于一個可驗證函數的評估。區塊鏈中的隨機數據已經有了過多的炒作。簡而言之,許多應用程序都依賴于隨機數生成,但是當所有鏈上操作都必須是確定性的并且可驗證,去識別大家都認可的隨機數是有一定難度的。

VRF會生成偽隨機數以及正確生成的證明。它們采用一些參數作為輸入。我們的VRF獲取一個時段隨機的種子,一個插槽號和作者的私鑰。因為沒有兩個節點具有相同的私鑰,所以每個節點可以為每個插槽生成唯一的偽隨機值。

因BNB Chain持續擁堵,鏈游Zuki Moba決定完全遷移到 Polygon:3月22日消息,BNB Chain鏈游 Zuki Moba 發布公告表示,由于 BNB Chain 上交易持續擁塞以及交易速度慢,許多用戶遭遇了交易中斷問題,因此決定將 Dapp、NFT 和 ZUKI 代幣、ZP 代幣從 BNB Chain 完全遷移到 Polygon 網絡。Zuki Moba 計劃于4月在 Polygon 上線主網。

據悉,ZukiMoba是一款以去中心化經濟應用社區為導向的MOBA電競游戲(多人在線對戰競技場)。游戲內NFT用于構建角色、游戲物品和元宇宙結構。去年11月,該項目完成140萬美元融資。(prnewswire)[2022/3/22 14:11:56]

在一段時期內每個創建者為每個插槽評估其VRF。對于每個輸出低于某個商定閾值的插槽,驗證者有權在該插槽中創立一個區塊。由于隨機插槽分配過程,有可能會導致具有多種參數的插槽也沒有區塊。稍后我們將討論如何處理。

動態 | POLY將于9月27日轉移至Bittrex International市場:據官方消息,Polymath(POLY)將于9月27日轉移至Bittrex International市場,屆時,美國用戶將無法訪問和進行相關幣種交易。Bittrex表示此舉不會影響Bittrex International上的非美國用戶。[2019/9/15]

BABE中的VRF以一個隨機性時段,時隙編號和驗證者私鑰作為輸入,并為一個插槽中的每個時隙輸出一個值。當區塊創建者的輸出低于網絡的閾值時,它將生成一個區塊作為該插槽的主要區塊指引者。

次要插槽

Poloniex臨時暫停ETH、ETC、BTC、LTC、ZEC和DGB充提:今日Poloniex交易所發布推特表示,交易所臨時暫停了ETH、ETC、BTC、LTC、ZEC和DGB的充值和提現以進行錢包維護。資金是安全的,錢包會在短時間內回復。[2018/4/22]

為了處理空插槽,BABE使用循環反饋模式。每個插槽都有次級負責人。如果沒有該插槽開端的主要負責人,則次要負責人將創建一個區塊。此后備將確保每個插槽都有一個區塊創建者,并有助于確保一致的區塊時間。

聯合BABE和GRANDPA

到目前為止,我們已經有GRANDPA來確定終端鏈和BABE來創建了新的區塊。自從單個插槽可以有多個負責人,因此BABE的某些鏈就會產生分叉。

選擇最佳延伸鏈的第一條規則很簡單:BABE必須建立在GRANDPA最終確定的鏈上。這是使用GRANDPA的要求之一。

使用GRANDPA的第二個更微妙的要求是區塊生產算法必須具有選擇“最佳”鏈的方法。此屬性導致BABE具有概率確定性。

最好的鏈在BABE只是由原創者創建的最多區塊的那條鏈。

一個BABE選擇最佳分叉鏈的示例

分叉在BABE中很常見,正如在GRANPA文章中討論的那樣,區塊生產是O,這意味著創建者只需要向所有人廣播新創建的區塊,而不需要每個人都向每個人發送消息。因此并非每個人都對未最終確定的鏈有相同的看法。

該系統使我們能夠高效地生產區塊,并使GRANDPA最終確定它們所要聚集的鏈。

該等誰的時鐘?

我們根據時間分配槽位,但是我們沒有單一時間觀念。每臺計算機都有自己的時鐘。我們不能使用中心化的時間服務,因為這就是單點攻擊。攻擊者可能會切斷NTP服務器,或者切斷它的控制權或采取控制措施,以采取更加不道德的行為,例如將不同的時間數據發送到不同的節點。

如果您有興趣,請考慮以下情形:

我收到您的消息說“是8:42:00。”我的時鐘顯示是8:42:03。可能發生以下三種情況之一:1.我們的時鐘同步,網絡傳送您的消息只花了3秒鐘。2.實際花費了1秒鐘來傳遞您的消息。我們的時鐘不同步2秒。3.你在騙我,這不是你的時鐘所說的。

現在設想一下當我的時鐘說8:41:59時,我收到了此消息。如果我相信您是在誠實地告訴我您的時鐘說了什么,那么我知道我們不同步,我必須將時鐘提前。我仍然不知道通過網絡傳遞所花費的時間,所以我不知道我們有多少不同步。

BABE使用相對時間給單個計算機的時鐘分配了槽位編號。當節點接收到一個區塊時,它將校對接收時間和與該塊關聯的插槽編號。然后它將槽數編號添加到每個區塊上,并用其中位數來預測未來的槽位。請記住,證者會事先知道要為其創建的插槽編號,因此他們可以對此進行檢查。

BABE中的區塊創建者使用區塊的接收時間創建了網絡時間視圖。他們將接受時間映射到未來,基于槽點時間來確定何時應該創建和發起一個區塊。

到目前為止,我們已經討論了鏈是如何被制造的和如何確認。我們下一個必須要解決問題是,如何使人們以正確的方式運行這些協議?本系列的最后一部分將討論運行時如何激勵運行BABE和GRANDPA以及對錯誤的懲罰。

閱讀有關安全性的第4部分->

原地址:https://polkadot.network/polkadot-consensus-part-3-babe/

翻譯:Mike

編輯:Mike

Tags:POLBABPOLYOLYPOLICEDOGEBaby Lil Flokiwexpoly幣怎么樣POLY幣

SHIB最新價格
ACK:ETHGlobal邀你共建web3基礎設施 | HackFS黑客松開啟報名-ODAILY

HackFS是一個由ETHGlobal發起的,致力于為Web3世界構建基礎設施的黑客松。ETHGlobal與ProtocolLabs(開發Filecoin和IPFS的組織)共同啟動了本次活動,本.

1900/1/1 0:00:00
300:行情分析:天雷勾地火,地動山也搖-ODAILY

市場解讀 大炮一響黃金萬兩,比特沒響以太先漲。以太絕非池中物,一遇消息便化龍。昨日不靠譜又搞事,在岸人民幣應聲大漲300個基點,創下三個月來新高;黃金收盤1860.

1900/1/1 0:00:00
USD:BTC高位震蕩,9300-9350空博取-ODAILY

央行數字貨幣研究所與滴滴達成戰略合作探索數字貨幣智慧出行場景應用7月8日消息,日前,央行數字貨幣研究所與滴滴出行正式達成戰略合作協議,共同研究探索數字人民幣在智慧出行領域的場景創新和應用.

1900/1/1 0:00:00
MIN:行情分析:行情走勢也像是原子組成分子的過程,萬物之理皆同 -ODAILY

BTC行情分析 今天稍微剖析詳細一點,我們解構一下1H周期是如何對4H周期走勢進行完成的,在之前我們一直在說.

1900/1/1 0:00:00
ETH:空頭再次被槍斃,比特幣真的迎來牛市了嗎?-ODAILY

最近比特幣的行情隨著盤整之后,繼續走高,再盤整再走高;雖然行情簡單,但是市場上很多朋友依然是去逆勢操作博取回調利潤,易天老師也是一樣;這這幾天一直看多的行情下.

1900/1/1 0:00:00
ETH2:各種利好來臨,為什么牛市還沒到來?-ODAILY

近日,盤面又進入了平淡期,近一個禮拜,除了周一進行過一次探底,整體還是在9300-9600區間運行,顯得異常冷清,歸根結底還是當前市場沒有新的熱點,沒有值得大家關注的點.

1900/1/1 0:00:00
ads