導讀
Cosmos是由Tendermint團隊構建的開源社區項目,它是一個由獨立的稱為Zone的區塊鏈組成的支持跨鏈交互的異構多鏈系統,和Polkadot一樣,也由中繼技術實現。Cosmos提供一套能夠完整搭建區塊鏈的SDK,作為一個跨鏈系統,其中最為關鍵的就是跨鏈協議相關的設計,今天我們就來詳細分析一下IBC協議的具體內容。
IBC初探
IBC是屬于Cosmos-SDK中一個特殊的模塊。之所以特殊,主要體現在IBC提供了區塊鏈之間的跨鏈能力。
從總體的流程來說,IBC的技術并沒有很復雜,應該來說協議本身不應太過復雜,這對于協議的使用者來說約束更小,更加靈活。
現在比如說A鏈上的Alice上需要發送10個ATOM代幣到B鏈上的Bob上,會經過下面的四個步驟。
▲?Tracking
A鏈上的IBC模塊會不斷的同步B鏈上的區塊頭信息,B鏈上的IBC同理。通過這種方式,雙方能夠實現跟蹤對方區塊鏈上的驗證者集合的變化,本質上來說,就是A鏈、B鏈相互維護了一個對方的輕節點。
安徽:依托區塊鏈等技術 提升煤礦智能化水平:安徽省發展改革委、省能源局等9家單位近日聯合印發《關于加快煤礦智能化發展的實施意見》,意見指出,要依托互聯網、大數據、人工智能、區塊鏈等先進技術,支持煤炭產業基礎設施轉型升級,推動煤炭生產管理模式和管理理念變革,提升煤礦智能化水平。到2025年,全省45%左右的煤礦基本實現智能化。(上海證券報)[2020/6/22]
▲?Bonding
當使用IBC初始化一筆跨鏈轉賬之后,A鏈上的10個ATOM事實上處于鎖定的狀態。
▲?Proof中繼
一份證明A鏈上已經鎖定10ATOM的“證據”會被路由到B鏈上的IBC模塊。
教育部學校規劃中心:利用區塊鏈等技術 推動人力資本定價體系的建立:4月9日,由教育部學校規劃建設發展中心在京發布《“未來路線圖”實驗學校發展指南1.0》。會議指出,要以大數據測量評價中心作為基礎,基于數智時代培養人才的需求,利用人工智能、大數據和區塊鏈等新技術,重構測量評價體系,全過程、全要素記錄學習者德智體美勞各方面的數據信息,從而為學習者全面發展和個性化需求提供大數據保障,提升綜合素質評價的科學性,建立科學全面可信的教育評價體系,進而推動人力資本定價體系的建立。(科技日報)[2020/4/10]
▲?驗證
B鏈結合A鏈的輕節點信息,對這份“證據”驗證通過之后,B鏈上會“鑄造”10份ATOMVoucher,這些Voucher可以進行后續的流通使用。當然這些Voucher也可以通過同樣的跨鏈方式返回到A鏈,A鏈上的ATOM代幣相應執行解鎖的操作。
IBC握手流程
IBC協議是Cosmos中最核心的接口協議,能夠實現區塊鏈間跨鏈消息的可信、可靠轉發,并有效進行流量控制、多路復用等功能。
聲音 | 韓國采購廳廳長:將運用區塊鏈等技術 全面改革公共采購市場:今日,韓國采購廳廳長鄭武警在政府大樓舉行記者招待會,他表示,今年將采購廳將利用120萬億韓元建設韓國公共采購市場,通過促進革新和支援,創造更多工作崗位,提高經濟活力。同時,將運用大數據、人工智能、區塊鏈等尖端智能信息技術,全面改革公共采購市場。[2019/3/7]
在Cosmos中,每個功能都是高度模塊化的,每個功能通過加載不同的模塊來實現,IBC也是如此。在IBC設計時,借鑒了傳輸層的TCP協議,也是希望成為區塊鏈領域的“TCP協議”。不僅如此,在IBC的各個方面也能看到TCP的身影,首先我們來看IBC中的一些基本概念。CosmosIBC采用了有連接的、可靠的跨鏈消息傳輸。
在此基礎上提出了以下幾個關鍵定義:
Client
Connection
Channel
下圖是IBC協議和TCP相關概念的對比。
聲音 | 俄羅斯央行行長:企業正在改進區塊鏈等新技術 尋找應用案例:俄羅斯央行行長Elvira Nabiullina在索契創新金融技術論壇上表示,近期,全球加密貨幣熱潮開始消退,企業對區塊鏈技術開始采取更為冷靜的態度。企業正在努力改進區塊鏈等新技術,尋找實際應用的案例。[2018/10/18]
可以看到連接、端口都是TCP協議中的規范,但是其中的內涵發生了變化,為了適應跨鏈場景下的使用。同時增加了通道和客戶端等新的內容,能夠支持跨鏈中的有序發送和跨鏈交易的驗證。
接下來我們來看一下一次完整IBC協議的握手和通信流程。
一筆跨鏈交易的連接流程如上圖,和TCP協議類似,IBC的建立需要建立多次的握手過程,并增加了一步初始化客戶端的操作,這對于跨鏈來說很關鍵的一環。
▲?鏈內客戶端
聲音 | 河北副省長陳剛:加快運用區塊鏈技術 打造高質量發展樣板:8月5日消息,省委常委、副省長,雄安新區黨工委書記、管委會主任陳剛強調:“要加快區塊鏈、大數據等技術研究運用,把制度建設和信息技術相融合,不斷扎緊監管制度的籠子,積極探索廉潔雄安建設的新路徑。”[2018/8/5]
跨鏈雙方需要在鏈上初始化一個對方鏈的輕客戶端,這個Client實質上是另一個區塊鏈的輕客戶端,而且必須滿足Cosmos規定的一套Client接口。之所以要在IBC建立之前初始化這個輕客戶端,是因為Cosmos需要保證在本鏈上能夠驗證來自來源鏈的跨鏈交易是能夠驗證的,否則無法保證在本鏈上執行該交易的有效性和合法性。
為了方便后續后續更多不同種類的區塊鏈接入,這個輕客戶端規定了一套通用的接口,不同類型的區塊鏈通過實現該Client來達到接入的效果。現階段Cosmos能夠支持TendermintClient和SoloClient,也就是同構鏈之間原生支持跨鏈。這也決定了不是使用Cosmos構建的區塊鏈想要接入CosmosHub進行跨鏈的話,必須通過一個額外的“轉接橋”,實現起來也更加復雜了。
▲?握手連接
在輕客戶端的基礎上建立握手連接,握手連接基本上分別為三個部分。
啟動跨鏈的用戶向鏈A發起OpenInit請求,等待Relayer接收到該請求。Relayer進行路由跨鏈消息包的工作,如果收到OpenInit的請求,Relayer會構造一個的OpenTry的請求發送到鏈B上。鏈B收到OpenTry請求之后,如果同意的話,會對該消息進行確認(生成OpenACK數據包,并按照之前的方式由?Relayer轉發給鏈A。鏈A通過OpenACK數據包判斷此次握手是否成功,如果成功,對此次握手發送最后的?OpenConfirm數據包返回鏈B。如果握手失敗,此次連接也就是建立失敗了。上面的步驟不僅是指Connection的建立過程,Channel的建立也是遵循同樣的流程,只是數據包的名稱和內容會有不同,像建立Connection的時候發送的便是ConnOpenInit請求,建立的Channel的時候便是ChanOpenInit請求,之后的請求依次類推。
需要說明的是,Connection和Channel在跨鏈扮演的角色和功能并不相同,按照Cosmos的設計,Connection和Client一起負責跨鏈交易的“合法性”——包括跨鏈交易確實在目的鏈上發生,以及跨鏈交易只提交了一次。而Channel用來保證跨鏈交易的有序性,每筆交易按照SequenceNumber來進行發送。
雖然在Cosmos設計中有提到可以實現無序的Channel,但是默認實現上是采用了有序的模式。如果按照TCP協議簇來類比的話,有序Channel和TCP類似,無序Channel類似于UDP,無序Channel按照UDP來講的話,在某些不太關注跨鏈消息包順序的場景下也是適用的。同時Cosmos設計中也考慮到Channel的消息發送能力,允許一條Connection上建立多個Channel,在不同的跨鏈應用場景中,可以使用不同的Channel發送消息,從而隔離不同業務。
▲?發送跨鏈數據包
完成上述的一系列握手之后,應用層便可以在Channel上發送自己的數據了。Cosmos規定了發送跨鏈交易的一些必要字段,如下圖:
其中Sequence和SourcePort字段都是承擔其字面意思的功能,也是必須指定的字段,而TimeoutHeight和TimeoutTimestamp是Cosmos提供的一種超時機制。如果某個區塊高度或者某個時間這筆跨鏈交易還沒有完成的話,用戶能夠指定將這筆交易回退。而Data字段是留給用戶進行自定義,以應對可能的各種復雜的跨鏈場景。
總結
通過上面對IBC的分析,我們可以看到IBC采用了建立連接的方式進行跨鏈,不同于Polkadot的XCMP協議,XCMP協議中平行鏈可以直接進行跨鏈消息的轉發。
而且Cosmos并沒有過分關注Zone作惡的情況,只是通過維護Zone的輕客戶端的方式驗證跨鏈交易的有效性,這種方式下是相信Zone不會出現集體作惡的情況,也就是Zone安全性由自身負責。不同于Polkadot設計上中繼鏈維護全局的安全性,CosmosIBC的設計上是減少了跨鏈系統的維護成本和降低了設計實現難度的。
作者簡介
陶勇星
來自數據網格實驗室BitXHub團隊主要負責區塊鏈賬本互操作技術相關研究工作
來源:澎湃新聞 記者:葉映荷 原標題:《526份問卷調查:大眾對數字人民幣知多少,會有多大接受度》隨著深圳、蘇州等地數萬人參與數字人民幣紅包測試,有關數字人民幣的討論熱度也持續升溫.
1900/1/1 0:00:00作者:RachelWolfson 編譯:陳一鳴鏈新 人們期待已久的對以太坊網絡的安全和可擴展性升級,已經按計劃于12月1日啟動,這對以太坊社區來說,是一個巨大的里程碑.
1900/1/1 0:00:000x協議發布推特提醒用戶參與V4版本的治理投票,此次投票于1月16日晚上啟動,預計將于1月23日結束.
1900/1/1 0:00:00在比特幣誕生十二年來,無論是采用還是價值上漲,它都交給了我們一份滿意的答卷。但比特幣的區塊容量卻在一種不那么令人滿意的方式增長著。 比特幣區塊鏈像每個中心化或者去中心化數據庫一樣是存儲數據的.
1900/1/1 0:00:00據EmergingEurope1月8日報道,斯洛文尼亞加密貨幣公司Eligma獲得400萬歐元融資,RogerVer旗下公司Bitcoin.com領投,使該公司估值達到5000萬歐元.
1900/1/1 0:00:00近日,在區塊鏈政務應用論壇上,可信區塊鏈計劃發布《政務區塊鏈發展白皮書》。本白皮書針對政務區塊鏈的本質特征及運行機理進行科學分析,并設計出政務區塊鏈的應用圖譜,同時全面匯編政務服務領域的區塊鏈應.
1900/1/1 0:00:00