### 處理兩個chan通道的消息
```
// HandleEvents 處理兩個chan通道的消息:Blocks和Transactions
// 將block消息或transaction消息通過節點的通信通道發布(Publish)到全網
func HandleEvents(net *Network) {
for {
select {
case block := <-net.Blocks:
? ? ? ? ? net.SendBlock("", block)
case tnx := <-net.Transactions:
//mine := false
? ? ? ? ? net.SendTx("", tnx)
}
}
}
```
### SendTx
```
func (net *Network) SendTx(peerId string, transaction *blockchain.Transaction) {
? ? memoryPool.Add(*transaction)
tnx := Tx{net.Host.ID().Pretty(), transaction.Serializer()}
payload := GobEncode(tnx)
request := append(CmdToBytes("tx"), payload...)
// 給全節點(FullNode)的通信通道發布此消息,全節點(FullNode)將進行處理
? ? net.FullNodesChannel.Publish("接收到 Send transaction 命令", request, peerId)
}
```
### Publish(channel.go)
```
// Publish 發布消息
func (channel *Channel) Publish(message string, payload []byte, SendTo string) error {
m := ChannelContent{
? ? ? ? Message: message,
? ? ? ? SendFrom: ShortID(channel.self),
? ? ? ? SendTo: SendTo,
? ? ? ? Payload: payload,
}
? ? msgBytes, err := json.Marshal(m)
if err != nil {
return err
}
//從Publish實現來看,pub系統實際上也是直接將msgBytes發送到全網,并不先做解析,因此構建的消息結構只有Data和Topic賦值了
//From和Seqno均設置為nil。這意味著必然接受到消息
return channel.topic.Publish(channel.ctx, msgBytes)
```
- 重要更新說明
- linechain發布
- linechain新版設計
- 引言一
- 引言二
- 引言三
- vs-code設置及開發環境設置
- BoltDB數據庫應用
- 關于Go語言、VS-code的一些Tips
- 區塊鏈的架構
- 網絡通信與區塊鏈
- 單元測試
- 比特幣腳本語言
- 關于區塊鏈的一些概念
- 區塊鏈組件
- 區塊鏈第一版:基本原型
- 區塊鏈第二版:增加工作量證明
- 區塊鏈第三版:持久化
- 區塊鏈第四版:交易
- 區塊鏈第五版:實現錢包
- 區塊鏈第六版:實現UTXO集
- 區塊鏈第七版:網絡
- 階段小結
- 區塊鏈第八版:P2P
- P2P網絡架構
- 區塊鏈網絡層
- P2P區塊鏈最簡體驗
- libp2p建立P2P網絡的關鍵概念
- 區塊鏈結構層設計與實現
- 用戶交互層設計與實現
- 網絡層設計與實現
- 建立節點發現機制
- 向區塊鏈網絡請求區塊信息
- 向區塊鏈網絡發布消息
- 運行區塊鏈
- LineChain
- 系統運行流程
- Multihash
- 區塊鏈網絡的節點發現機制深入探討
- DHT
- Bootstrap
- 連接到所有引導節點
- Advertise
- 搜索其它peers
- 連接到搜到的其它peers
- 區塊鏈網絡的消息訂發布-訂閱機制深入探討
- LineChain:適用于智能合約編程的腳本語言支持
- LineChain:解決分叉問題
- LineChain:多重簽名
- libp2p升級到v0.22版本
- 以太坊基礎
- 重溫以太坊的樹結構
- 世界狀態樹
- (智能合約)賬戶存儲樹
- 交易樹
- 交易收據樹
- 小結
- 以太坊的存儲結構
- 以太坊狀態數據庫
- MPT
- 以太坊POW共識算法
- 智能合約存儲
- Polygon Edge
- block結構
- transaction數據結構
- 數據結構小結
- 關于本區塊鏈的一些說明
- UML工具-PlantUML
- libp2p介紹
- JSON-RPC
- docker制作:啟動多個應用系統
- Dockerfile
- docker-entrypoint.sh
- supervisord.conf
- docker run
- nginx.conf
- docker基礎操作整理
- jupyter計算交互環境
- git技巧一
- git技巧二
- 使用github項目的最佳實踐
- windows下package管理工具