當調用Filecoin全節點的
start方法啟動全節點時,調用hello協議的
New方法,這個方法的處理如下:
生成Hello對象。hello?:=?&Handler{
????host:??????????????h,
????genesis:???????????gen,
????chainSyncCB:???????syncCallback,
????getHeaviestTipSet:?getHeaviestTipSet,
????net:???????????????net,
????commitSha:?????????commitSha,
}
其中host對象為底層libp2提供的Host對象;genesis為創世區塊的CID;chainSyncCB為全節點對象的syncCallBack函數,用于從遠程節點同步區塊;getHeaviestTipSet為porcelain.API對象的ChainHead方法,用于返回區塊鏈頭部的tipset;net表示當前的網絡環境,比如測試網、正式網;
調用host對象的SetStreamHandler方法,設置自身的handleNewStream方法作為/fil/hello/1.0.0協議的處理器。h.SetStreamHandler(protocol,?hello.handleNewStream)
香港金發局發布2022/23年報:香港正將自己定位為開發虛擬資產及科技互補全球領導者:金色財經報道,香港金融發展局(金發局)發布2022/23年報,其中指出在全球Web 3.0發展中,香港具有發揮領導作用的有利條件,包括它是一個國際金融中心、擁有豐富本地專業和適合國際投資者的監管框架。Web 3.0為年輕專業人士提供了一系列新的就業機會,香港政府為銀行和其他中介機構提供了機會,使其能夠與持牌交易所合作以提供虛擬資產交易服務,代幣化將在香港發揮重要作用,將債券、股票甚至房地產等傳統資產帶入新的數字范式。香港正在將自己定位為開發虛擬資產及科技互補(如區塊鏈及Web 3.0)的全球領導者。[2023/7/28 16:04:34]
當連接建立時,通過后面注冊的通知者,從而調用sayHello方法,在這個方法中打開一個hello協議的流,并發送hello消息。
調用Host對象的網絡對象的Notify方法,把自身作為被通知者注冊到網絡對象上。h.Network().Notify((*helloNotify)(hello))
在這一步,通過調用host對象的Network方法,返回底層的swarm對象,然后把hello對象轉化為helloNotify對象,最后調用swarm對象的Notify方法,從而當底層的swarm對象有任何事件發生時都會通知helloNotify對象。
Gnosis Chain擬在鏈上部署Spark Protocol:7月6日消息,Gnosis金庫管理方Karpatkey發起一項社區提案,提議在Gnosis Chain啟動MakerDAO旗下借貸協議Spark Protocol。
此前報道,MakerDAO宣布其借貸協議Spark Protocol將擴展至多鏈,并公布了有興趣在特定域(各種區塊鏈網絡)中部署Spark Protocol的步驟與流程。[2023/7/6 22:20:39]
在Hello協議中我們只關心建立連接事件,所以helloNotify類型只實現了這個方法,其他方法都為空實現,具體如下:
type?helloNotify?Handler
func?(hn?*helloNotify)?hello()?*Handler?{????return?(*Handler)(hn。
const?helloTimeout?=?time.Second?*?10
func?(hn?*helloNotify)?Connected(n?net.Network,?c?net.Conn)?{????go?func()?{????????ctx,?cancel?:=?context.WithTimeout(context.Background(),?helloTimeout)????????defer?cancel()????????p?:=?c.RemotePeer()????????if?err?:=?hn.hello().sayHello(ctx,?p);?err?!=?nil?{????????????log.Warningf("failed?to?send?hello?handshake?to?peer?%s:?%s",?p,?err)????????}????}(。
區塊鏈視頻流平臺Theta的去中心化數據流和傳輸網絡中的跟蹤服務器獲美國專利:5月31日消息,基于區塊鏈的視頻流平臺 Theta Network 宣布其去中心化數據流和傳輸網絡中的跟蹤服務器已獲得美國專利,專利中描述的去中心化流媒體網絡是一個多層全局緩存,包括對等查看器、邊緣節點和 CDN 服務器,跟蹤器服務器協調數據片段的傳輸和支付。[2023/5/31 11:50:07]
當節點作為客戶端,撥號連接到遠程對等節點時,底層的swarm對象會調用自身的notifyAll方法,通知所有的Notify對象有連接被打開,即調用所有Notify對象的Connected方法,包括前面我們注冊的通知對象。當調用helloNotify對象的Connected方法時,這個方法內部調用自身的hello方法,后者返回自身并強制轉化為Handler類型,然后調用它的sayHello方法,對我們當前連接的遠程進行打招呼。
與此同時,當遠程節點作為服務器,接收到我們發送的連接請求生成連接時,它的swarm對象也會通知它的所有Notify對象,從而也會它的前面注冊的通知對象,即調用服務器商的Connected方法,從而調用它的sayHello方法向我們發送它的區塊情況;因為第二步中,我們把Hello對象的handleNewStream方法注冊為Hello協議的處理器,所以當節點接收到遠程節點發送區塊情況時,就會調用這個方法進行處理,這個方法又會調用調用全節點的syncCallBack方法進行區塊同步處理。
Ark Invest增持42萬股Coinbase股票:11月9日消息,在幣安簽署收購FTX非美國業務協議消息傳出后,“木頭姐”Cathie Wood管理的Ark Investment Management LLC旗下三支基金在本周二(11月8日)總計購買了超過420,000股的Coinbase股票。在此之前,Ark Investment還于10月24日增持了Coinbase股票。(彭博社)[2022/11/9 12:36:47]
總體上來說,Hello協議通過
sayHello和
handleNewStream開啟了區塊同步,前者把自身的區塊情況發送到遠程節點,后者處理遠程節點發送的區塊情況。
sayHello方法處理如下:
調用Host對象的NewStream,生成一個處理Hello協議的流對象。s,?err?:=?h.host.NewStream(ctx,?p,?protocol)
if?err?!=?nil?{
????return?err
}
defer?s.Close()?//?nolint:?errcheck
調用自身的getOurHelloMessage方法,獲取自身區塊鏈頂端的信息。msg?:=?h.getOurHelloMessage()
美國財政部長:衰退并非不可避免,美聯儲加息正在幫助遏制通脹:金色財經消息,美國財政部長Janet Yellen在接受NBC采訪時稱,美國經濟增長正在放緩,但衰退并非不可避免。Yellen指出,強勁的美國招聘數據和消費者支出表明美國經濟目前并未陷入衰退。
Yellen還表示,美國通脹“太高了”,而最近美聯儲加息正在幫助遏制物價飆升。(路透社)[2022/7/25 2:35:07]
這個方法內部執行流程如下:
調用自身getHeaviestTipSet方法,獲取區塊鏈頂端的信息這個方法是plumbing.API對象ChainHead方法的引用。
使用獲取到的區塊鏈信息,生成并返回消息對象Message。
通過流發送區塊信息到遠程節點。
handleNewStream方法處理如下:
生成消息對象Message,并從流中讀取遠程對等節點發送過來的內容到消息對象中。var?hello?Message
if?err?:=?cbu.NewMsgReader(s).ReadMsg(&hello);?err?!=?nil?{
????log.Debugf("bad?hello?message?from?peer?%s:?%s",?from,?err)
????helloMsgErrCt.Inc(context.TODO(),?1)
????s.Conn().Close()?//?nolint:?errcheck
????return
}
調用自身的processHelloMessage方法,處理遠程節點發送的消息。這個方法代碼如下:func?(h?*Handler)?processHelloMessage(from?peer.ID,?msg?*Message)?error?{
????if?!msg.GenesisHash.Equals(h.genesis)?{
????????return?ErrBadGenesis
????}
????if?(h.net?==?"devnet-test"?||?h.net?==?"devnet-user")?&&?msg.CommitSha?!=?h.commitSha?{
????????return?ErrWrongVersion
????}
h.chainSyncCB(from,?msg.HeaviestTipSetCids,?msg.HeaviestTipSetHeight)
return?nil
}
它的處理邏輯比較簡單:
首先,檢查遠程節點發送的創世區塊哈希是否自身的創世區塊哈希相等。如果不等,直接返回錯誤。
然后,檢查網絡類型。
最終,調用自身的chainSyncCB方法,處理遠程節點發送的區塊信息。這個同步回調方法對象在全節點的啟動方法Start中生成。它的主要生成就是根據遠程節點發送的區塊鏈最頂層的信息,生成一個types/SortedCidSet對象,然后調用chain/syncer.go中的HandleNewTipset方法來處理遠程發送的區塊信息。
根據前面處理消息的結果進行不同的處理。switch?err?:=?h.processHelloMessage(from,?&hello);?err?{
case?ErrBadGenesis:
????log.Debugf("genesis?cid:?%s?does?not?match:?%s,?disconnecting?from?peer:?%s",?&hello.GenesisHash,?h.genesis,?from)
????genesisErrCt.Inc(context.TODO(),?1)
????s.Conn().Close()?//?nolint:?errcheck
????return
case?ErrWrongVersion:
????log.Debugf("code?not?at?same?version:?peer?has?version?%s,?daemon?has?version?%s,?disconnecting?from?peer:?%s",?hello.CommitSha,?h.commitSha,?from)
????versionErrCt.Inc(context.TODO(),?1)
????s.Conn().Close()?//?nolint:?errcheck
????return
case?nil:?//?ok,?noop
default:
????log.Error(err)
}???
12月2日消息,全球四大會計師事務所之一的安永于近日披露了其用于資產通證化的以太坊公鏈智能合約地址.
1900/1/1 0:00:00國際清算銀行總經理奧古斯丁·卡斯滕斯似乎已改變了對央行數字貨幣的負面立場,現在表示此類貨幣可能會開辟新的可能性.
1900/1/1 0:00:00文/DenisBeau 翻譯/龍白滔 點評/龍白滔 點評 本發言內容相對簡單和清晰,筆者無意針對發言內容做點評,但希望借“金融包容性”發揮一下.
1900/1/1 0:00:00轉眼又是年終,是時候做總結了!之前2017-2019的帖子刷爆了微博朋友圈,小編掐指一算,可巧了不是,鏈節點直播間也是正好兩周年紀念!直播間經歷了充滿機遇與挑戰的兩周年也獲得了滿滿的成長和經驗.
1900/1/1 0:00:00國內目前電子證照管理平臺主要依托第三方認證機構建立中心數據庫存儲數據,采用集中化數據庫來完成證照的制作、存儲、信息查詢和交換共享,數據訪問和更新權限屬于國家機關,各部門共享.
1900/1/1 0:00:00據Cointelegraph11月26日報道,Blockstream首席執行官亞當?巴克在一次專訪中表示,對他而言,比特幣是至高無上的,甚至連央行發行的穩定幣或其他數字貨幣都無法與之媲美.
1900/1/1 0:00:00