——背景——
當前,區塊鏈跨鏈平臺的接入方式在架構設計上存在著較大差異,如何將應用鏈快速、便捷地接入跨鏈系統是一個亟待解決的問題。趣鏈BitXHub跨鏈服務平臺采用中繼鏈+網關的跨鏈方案,其中,跨鏈網關擔任著區塊鏈間收集和傳播交易的角色。采用插件機制的設計將網關與應用鏈交互的模塊與跨鏈網關核心功能模塊進行解耦,從而實現不同種類應用鏈高效地接入跨鏈系統。在Pier運行時,通過動態加載插件的方式完成不同應用鏈的靈活適配。為了更好的提升Pier與應用鏈的交互能力,具體應用鏈插件需要根據不同區塊鏈的特性實現具體的接口,交互接口需要滿足以下幾個功能:
1)監聽應用鏈上的跨鏈事件并傳給核心模塊進行處理;
2)執行來自于網關發出的跨鏈請求;
Meme項目FLOKI:FlokiFi Locker TVL突破600萬美元:1月30日消息,Meme項目FLOKI發推稱,FlokiFi Locker TVL已突破600萬美元。FLOKI表示,FlokiFi Locker旨在為FLOKI代幣提供實用性。[2023/1/30 11:36:08]
3)能夠主動查詢應用鏈上已收到和已執行的跨鏈請求狀態。
在插件實現方案的設計中,我們先后采用了兩種不同的插件機制,下面就來介紹一下我們使用原生插件時碰到的問題以及新插件方案的優勢。
——原生插件——
go語言從1.13版本開始支持編譯為插件,使用方式如下
gobuild--buildmode=plugin-oappchain.so*.go
比特幣全網未確認交易數量為11325筆:金色財經報道,BTC.com數據顯示,目前比特幣全網未確認交易數量為11325筆,全網算力為229.88 EH/s,24小時交易速率為3.35交易/s,目前全網難度為31.36T,預測下次難度上調2.51%至32.15 T,距離調整還剩10天20小時。[2022/10/1 18:36:37]
go項目在編譯時可以通過--buildmode指定為插件模式,這種方式將輸出為動態鏈接文件。該文件并非可直接運行的二進制文件,而是提供給其他二進制運行時的動態調用。
在主二進制文件中的使用方式如下:
樂天集團子公司將對Blocko投資約384萬美元:7月7日消息,區塊鏈基礎設施提供商 Blocko 確認樂天集團營銷子公司在對其進行兩個來月的盡職調查后決定對其投資 50 億韓元(約 384 萬美元)。文章表示,該筆投資有望推動 Blocko 在韓國交易所 KOSDAQ 的上市進程。
據悉,Blocko 成立于 2014 年,核心業務是托管服務提供商業務,2018 年開發區塊鏈主網 Aergo,并發行了同名加密貨幣 AERGO。[2022/7/7 1:57:38]
總結來說原生插件具有以下特點:
優點:
1)使用體驗和原生代碼一致,類似于代碼模塊的二進制化;
2)效率較高,插件直接在主程序進程空間中運行。
廣州成功落地首筆數字人民幣線上消費貸款業務:金色財經報道,近日,在中國人民銀行廣州分行的大力支持下,中國郵政儲蓄銀行聯合中郵消費金融有限公司在廣州落地數字人民幣消費貸款場景,成功發放了首筆“郵你貸”個人消費貸款,拓展全流程線上化數字人民幣貸款的創新實踐。(中國新聞網)[2022/7/3 1:47:47]
缺點:
1)原生插件中的依賴庫與主程序必須保持完全一致,否則啟動的時候會報錯,而且不論這個依賴是直接引用還是間接引用,都會出現這個問題。
——轉戰RPC插件——
原生插件中嚴厲的版本限制,使得在升級插件和或網關主程序功能時,可能因為無意升級了主程序某些依賴,插件也必須作出相同的適配升級。這種方式不利于插件的完全解耦,因此我們轉向了另外一個使用RPC方式的GO插件項目。
在GO原生支持的插件機制出現之前,hashicorp的go-plugin就已經存在,不過GO原生插件出來之后,他們也并沒有放棄對該項目的支持,因為總的來說原生插件并不是很完善,在某些場景下還是go-plugin更方便。
go-plugin插件的使用方式如下:
簡單來說,go-plugin項目實現的插件方式采用了C/S模式,主程序作為RPCClient,具體插件作為RPCServer,Server和Client通信也是基于的interface接口規范來通信。
具體使用流程如下:
1)抽象需要插件化的interface,這里直接復用原生插件中使用的接口定義即可;
2)針對Client端和Server端,都實現上述接口。Server端的實現是具體的插件處理邏輯部分的代碼;Client端的實現只需封裝一下gRPC處理的結果和異常信息,之后便可以做到主程序在使用插件時對于gRPC的弱感知化。
Server實現部分:
Client實現部分:
▲額外需要注意的是:
插件中需要調用plugin.Serve來授權主程序使用自己的RPC服務。這里需要注意的是,主程序和插件通信前需要進行握手,主要包括確認該插件的版本信息。
主程序使用plugin.Client對象啟動插件,該插件是運行在另一個進程中的,所以插件崩潰并不會影響到主程序。
client與server在使用中實際上是通過進程間Socket來完成通信,這雖然犧牲了一定的性能卻換來了原生插件的單進程方案所不具備的依賴解耦?多語言支持等靈活應用。
——結語——
go-plugin提供兩種通信方式的選擇,一種是GRPC,一種是GO語言標準庫中自帶的net/rpc。GRPC插件的好處是可以采用不同的語言來實現,并且Googleprotobuf也是支持多語言的。網關插件本質上已成為連接應用鏈并實現對網關提供RPC服務的橋梁,開發者在跨語言編寫插件時的阻礙會大大降低,在面對不同應用鏈特性時也能做到更加可靠與簡潔的邏輯呈現。對跨鏈技術感興趣的小伙伴,添加小助手桔子加入技術交流群,共論區塊鏈的無限未來~
作者簡介
王荻矣
趣鏈科技數據網格實驗室BitXHub團隊
最近的加密貨幣市場一直處于動蕩調整之中,恐慌指數直線拉升,但NFT的熱度卻不降反升。數據顯示,中國的NFT搜索量自今年2月底開始,4個多月迅速飆升了逾34倍,截至7月23日,中國在全球NFT搜索.
1900/1/1 0:00:00什么是layer2?從狀態通道到RollUp以太坊區塊鏈日趨廣泛使用,但是協議的負載量卻十分有限,使得鏈上十分擁堵,而且手續費越來越高,許多大規模應用無法在以太坊網絡實現.
1900/1/1 0:00:00是時候參加巴林和澳大利亞F1?DeltaTime聯合大獎賽(GrandPrix?)了!我們為本周的計時賽和GrandPrix?大獎賽共準備了160.
1900/1/1 0:00:002021年,是加密貨幣行業不平凡的一年。在這一年中,得益于加密貨幣點對點、交易費用低等特點。使得加密貨幣市場經歷了巨大的增長,加密貨幣/區塊鏈行業也獲得了廣泛的關注度.
1900/1/1 0:00:00BTC行情分析 目前的基本面沒有什么消息可以剖析,如果有,本周末最大的消息莫過于證券時報對數字人民幣的10+1城市的應用落地.
1900/1/1 0:00:00今年5月份,Twitter官方曾表示,希望讓用戶在互相關注、轉發、點贊之外能夠更好地互相支持,因此平臺將引入TipJar功能——讓用戶能夠互相發送和接收小費。現在,此事又有了最新的進展.
1900/1/1 0:00:00