日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

php小編西瓜在這里回答你的問題。是的,你可以在Hyperledger Chaincode中使用gRPC。gRPC是一種高性能、開源的遠程過程調用(RPC)框架,它可以使您的Chaincode與其他服務進行通信。為了避免在測試網絡上調用期間出現錯誤,您可以采取以下幾個步驟。首先,確保您的測試網絡已經正確配置和運行。其次,檢查您的代碼和配置文件以確保正確地使用gRPC。最后,進行適當的錯誤處理和日志記錄,以便及時發現和解決任何問題。通過這些步驟,您應該能夠避免在測試網絡上調用期間出現錯誤,并順利地使用gRPC進行通信。

問題內容

我想在fabric chaincode中使用grpc來實現跨鏈通信,而不是使用fabric sdk。
但是當我在fabric-sample/test-network上調用chaincode函數時,總是會出現錯誤。

error: endorsement failure during invoke. response: status:500 message:"error in simulation: failed to execute transaction eb5e480bd4075a767f56ae263741ca0f5f19620ef88952e26b7f1952bdbe83cd: could not launch chaincode chaincode_1.2:d3f97f15a635e73d3de230c8e5899e5fb95a68cf897c03e19f9e4eeca7ca3fd5: chaincode registration failed: container exited with 2"

登錄后復制

誰能告訴我這個錯誤是什么原因造成的?
我的鏈代碼有 bug 或者 grpc 無法在鏈代碼函數中使用?

我關于 grpc 的鏈代碼:

func (s *smartcontract) begin(ctx contractapi.transactioncontextinterface) error {
    server.main()
    return nil
}

func (s *smartcontract) client(ctx contractapi.transactioncontextinterface) error {
    // client.clientfunc is the client main function
    client.clientfunc(xt, r, sign, m)
}

登錄后復制

服務器.go

func main() {
    listen, err := net.listen("tcp", ":9090")
    if err != nil {
        fmt.printf("failed to listen: %v", err)
        return
    }
    grpcserver := grpc.newserver()
    pb.registersendserviceserver(grpcserver, &server{})
    err2 := grpcserver.serve(listen)
    if err2 != nil {
        fmt.printf("failed to serve: %v", err2)
        return
    }
}

登錄后復制

client.go

func Clientfunc(Xt *btcec.PublicKey, R *btcec.PublicKey, s *big.Int, m []byte) []byte {
    conn, err := grpc.Dial("127.0.0.1:9090", grpc.WithTransportCredentials(insecure.NewCredentials()))
    if err != nil {
        log.Fatalf("did not connect: %v", err)
    }
    defer conn.Close()
    client := pb.NewSendServiceClient(conn)
    output := &pb.SignInput{
        XtX: Xt.X().Int64(),
        XtY: Xt.Y().Int64(),
        M:   m,
        RX:  R.X().Int64(),
        RY:  R.Y().Int64(),
        S:   s.Int64(),
    }
    resp, _ := client.Send(context.Background(), output)
    return resp.GetM()
}

登錄后復制

解決方法

誰能告訴我這個錯誤是什么原因造成的?

詳見 hyperledger fabric v2.x/ 日志控制,什么可以告訴你是什么導致了 錯誤 500 (內部服務器錯誤)是服務器日志

取決于您的運行方式:

docker logs 
kubectl logs -n  
oc logs -n  

登錄后復制

這可能是由于您的鏈代碼中的問題(例如 grpc 代碼中的錯誤),或者可能是由于鏈代碼運行的環境所致。

從您的代碼中,您可能會考慮在鏈代碼中啟動 grpc 服務器 (server.main())。 chaincode 在 hyperledger fabric 網絡中運行,并不像獨立應用程序那樣處理網絡通信。
相反,您應該使 grpc 服務器成為獨立運行的單獨服務,然后鏈代碼可以根據需要與該服務進行通信。

加上client.clientfunc()函數似乎建立了grpc連接,發送請求,并等待響應。這是同步操作,如果響應需要很長時間才能到達,則可能會出現問題。最好使用異步操作(即發送請求并在回調函數中處理響應)以避免阻塞鏈碼執行。
而且…您不應該忽略來自 client.send() 的錯誤;)

確保您的 grpc 服務器不需要安全連接,否則 grpc.withtransportcredentials(insecure.newcredentials()) (沒有 ssl/tls 的不安全連接)將會失敗。

通常,建議在 fabric 客戶端應用程序中處理與外部系統(例如通過 grpc)的通信,而不是在鏈代碼本身內。

如果我只想使用鏈碼而不是結構應用程序,有沒有辦法在不同渠道的組織之間進行通信?

不同渠道上的組織之間的通信可能很復雜,因為它是 hyperledger fabric 設計的一個基本方面,渠道相互隔離,以維護數據隱私。

您可能會考慮:

鏈碼函數:一個組織可以在自己的通道上調用鏈碼函數,該通道又調用另一個通道上的鏈碼函數。這是可能的,因為鏈碼可以與多個通道關聯。
請注意,此方法有一個限制,即第二個函數調用與第一個函數調用不屬于同一事務,因此如果第一個事務失敗,則無法回滾。

雙重會員:一個組織可以屬于多個渠道。因此,它可以從一個通道讀取數據并將數據寫入另一通道。但是,這是在兩個單獨的事務中完成的,因此無法保證原子性。

私有數據收集 (pdc):如果目標是在特定組織之間(甚至跨不同渠道)共享私有數據,pdc 可能是一種選擇。 pdc 允許通道上定義的組織子集認可、提交或查詢私有數據,而無需將數據分發到通道上的所有組織。

互操作性解決方案:還有更多針對區塊鏈互操作性的高級解決方案正在開發中,例如 interledger protocol (ilp),可用于在不同 fabric 網絡之間(甚至在完全不同類型的區塊鏈網絡之間)移動數據或資產。
然而,這些技術仍主要處于研發階段,可能尚未準備好投入生產使用。

分享到:
標簽:區塊鏈
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定