登录
首页 >  Golang >  Go问答

Fabric GO SDK 的背书政策问题

来源:stackoverflow

时间:2024-04-30 09:51:33 432浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《Fabric GO SDK 的背书政策问题》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

问题内容

我有一个超级账本结构测试网,有 2 个组织、org1 中的 3 个对等点和 org2 中的 2 个对等点。每个组织的peer0 是锚点。我想实例化一个仅具有一个组织的背书策略的链代码:org1,因此我指定策略:“and('org1msp.member')”。

我只在 org1 的同级中安装了链码,因为 org2 不是背书者。但是,链代码不会实例化,因为它将提案发送到其他组织 (org2) 中的对等点。

问题是因为 org2 中的这些节点没有安装链代码,但是...为什么 sdk 向不属于背书策略的节点发送背书请求?

这是我的配置文件,如您所见,我只有 org1 的一个对等点:https://gist.github.com/mtnieto/02dd17097de64a73bd627594056598ed

我已在配置中添加了以下功能,但它不起作用。

channels:

  # multi-org test channel
  examplechannel:

    peers:
      peer0.org1.example.com:
        endorsingpeer: true
        chaincodequery: true
        ledgerquery: true
        eventsource: true
      peer1.org1.example.com:
        endorsingpeer: false
        chaincodequery: false
        ledgerquery: true
        eventsource: true


      peer2.org1.example.com:
        endorsingpeer: false
        chaincodequery: false
        ledgerquery: true
        eventsource: true

      peer0.org2.example.com:
        endorsingpeer: false
        chaincodequery: false
        ledgerquery: true
        eventsource: true

      peer1.org2.example.com:
        endorsingpeer: false
        chaincodequery: false
        ledgerquery: true
        eventsource: true

日志如下:

"error": "创建 chaincode 时出错:发送部署交易 提案失败:发生多个错误: - 事务处理 对于背书者 [peer0.org2.example.com:8051]:背书者客户端状态 代码:(23) chaincode_name_not_found。描述:无法获取包 对于链码(examplecc:2) - 背书者的交易处理 [peer1.org2.example.com:6051]:背书者客户端状态代码:(23) chaincode_name_not_found。描述:无法获取包裹 链码(示例cc:2)”

实例化链码的代码如下。 (在之前的阶段我已经安装了链代码)

sdk, err = fabsdk.new(config.fromfile("config.yaml"))
    if err != nil {
        log.errorf("failed to create new sdk: ", err)
        return nil, err
    }

admincontext := sdk.context("admin", "org1"))
// org resource management client
orgresmgmt, err := resmgmt.new(admincontext)
if err != nil {
    log.errorf("failed to create resource management client %v: ", err)
    return nil, err

}


ccpolicy, err := cauthdsl.fromstring(instantiatereq.endorsmentpolicy)
if err != nil {
    log.errorf(" error parsing endorsment policy %v: ", err)
    return "", err
}   

instantiaterequest := resmgmt.instantiateccrequest{name: instantiatereq.name, path: instantiatereq.path, version: instantiatereq.version, args: instantiatereq.args, policy: ccpolicy}

当对等方更新为锚点时,会发生这种情况。换句话说,如果我在初始化网络时不在对等点中执行以下命令,则不会发生错误。

(在peer0 org1上下文中)

peer channel update -o orderer0.example.com:7050 -c $channel_name --tls $core_peer_tls_enabled --cafile $orderer_ca -f ./channel-artifacts/org1mspanchors.tx >&log.txt

在peer0 org2上下文中

peer channel update -o orderer0.example.com:7050 -c $CHANNEL_NAME --tls $CORE_PEER_TLS_ENABLED --cafile $ORDERER_CA -f ./channel-artifacts/org2MSPanchors.tx >&log.txt

解决方案


这是1.4.1版本中的一个错误,非背书者组织正在尝试执行lscc并背书交易。

我已经将网络升级到1.4.2,现在看来问题已经消失了。

理论要掌握,实操不能落!以上关于《Fabric GO SDK 的背书政策问题》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>