数据转发至BCS可信上链
场景说明
通过IoTDA规则流转能力实现自动调用合约将数据流转到BCS区块链服务实现数据可信上链,助力客户构建可信多方协作平台,使用区块链可减少人为纠纷,提高交易效率;区块链的不可篡改性降低了欺诈和网络错误的发生;共享的账本、流程、记录增进参与方之间的可信度;审计机构可随时对不可篡改的账本进行审计。IoTDA企业版实例支持将数据流转到BCS华为云区块链引擎实例(推荐)和Hyperledger Fabric增强版。
本示例分为两部分,将设备上报的数据转发到华为云区块链引擎实例(推荐)和Hyperledger Fabric增强版上链。
Hyperledger Fabric增强版由于开源内核限制,不支持高tps场景使用。建议使用性能更好的华为云区块链引擎实例。
转发华为云区块链引擎实例
一、购买华为云区块链引擎实例
- 登录华为云,访问区块链服务BCS,进入区块链服务管理控制台。
- 选择“实例管理”,单击购买华为云区块链引擎,按照需求选择华为云区块链引擎规格,单击“立即创建”。
图1 购买华为云区块链引擎
- 单击进入购买的华为云区块链引擎实例,选择“合约管理”,安装您开发好的合约(可参考合约开发),并选择合适的背书策略。
图2 安装合约
二、配置设备接入服务
在设备接入服务中设置数据转发规则,实现当设备上报数据时将数据作为参数调用华为云区块链合约实现数据上链。
- 访问设备接入服务,单击“立即使用”进入设备接入控制台。
- 在左侧导航栏选择“规则>数据转发”,单击左上角的“创建规则”。
- 参考下表参数说明,填写规则内容。以下参数取值仅为示例,您可参考数据转发简介创建自己的规则,填写完成后单击“创建规则”。
表1 创建规则参数说明 参数名
参数说明
规则名称
自定义,如“iotda-bcshw”。
规则描述
自定义,如“数据转发至Bcs华为云区块链实例”。
数据来源
选择“设备属性”。
触发事件
自动匹配“设备属性上报”。
资源空间
选择“所有资源空间”。
- 单击“设置转发目标”页签,单击“添加”,设置转发目标,设置完成后单击“确定”按钮。
表2 创建转发目标参数说明 参数名
参数说明
转发目标
选择“区块链服务(BCS)-华为云区块链”。
区域
选择数据上链的BCS华为云区块链实例所在的区域。
实例
选择数据上链的BCS华为云区块链实例。
访问方式
- 标准通道:应用访问区块链系统使用EIP方式。
- 高性能通道:应用访问区块链系统使用VPCEP方式,应用访问区块链流量较大场景时,建议使用VPCEP方式。单击“前往创建终端节点”。
- 计费方式选择默认按需计费,选择IoTDA企业版所在私有云和子网。
- 单击“立即创建”。
- 确认信息无误后,勾选协议和免责声明,并单击“提交”。
- 创建成功后,单击刷新,即可选择已创建成功的终端节点。
接入组织
选择上链的身份组织。
背书组织
选择上链背书的组织,需要和合约的背书策略保持一致才能正常上链。
合约
选择上链所需要调用的合约。
合约函数
填写上链需要调用的合约函数。
参数配置
配置转发字段与调用合约函数的参数下标的映射,转发字段可以参考设备属性上报通知。如设备Id:notify_data.header.device_id
图3 新建转发目标-转发至BCS-华为区块链
- 单击“启动规则”,激活配置好的数据转发规则。
三、验证操作
- 您可以使用配置设备接入服务时注册的真实设备接入平台,上报任意数据。
- 您也可以使用模拟器模拟设备上报数据,操作方法请参考在线开发MQTT协议的智慧路灯。
期望结果:
登录华为云区块链BCS控制台, 单击“区块链浏览器”,可以在交易列表中看到新增交易内容。
,进入数据上链的华为云区块链引擎实例,单击右侧转发Hyperledger Fabric增强版
一、购买yperledger Fabric增强版
- 登录华为云,访问区块链服务BCS,进入区块链服务管理控制台。
- 选择“实例管理”,单击购买华为云区块链引擎,按照需求选择Hyperledger Fabric增强版规格,单击“立即创建”。
图5 购买Hyperledger Fabric增强版
购买Hyperledger Fabric增强版选择和购买IoTDA企业版同一VPC可支持内网通信,可在“实例管理 > Hyperledger Fabric增强版”实例列表中,在对应Hyperledger Fabric增强版实例右上方选择“更多 > 更新访问地址”将接入地址修改为内网地址。
- 在“实例管理 > Hyperledger Fabric增强版”实例列表中,找到购买的Hyperledger Fabric增强版实例,进入“区块链管理”界面,选择左侧“链代码管理”,单击“安装链代码”安装您开发好的链代码(可参考链代码开发)。
图6 安装链代码
- 安装完成后单击安装的链代码右侧的“实例化”操作,在对应通道选择合适的背书策略完成实例化。
图7 链代码实例化
二、配置设备接入服务
在设备接入服务中设置数据转发规则,实现当设备上报数据时将数据作为参数调用华为云区块链合约实现数据上链。
- 访问设备接入服务,单击“立即使用”进入设备接入控制台。
- 在左侧导航栏选择“规则>数据转发”,单击左上角的“创建规则”。
- 参考下表参数说明,填写规则内容。以下参数取值仅为示例,您可参考数据转发简介创建自己的规则,填写完成后单击“创建规则”。
表3 创建规则参数说明 参数名
参数说明
规则名称
自定义,如“iotda-bcsfabric”。
规则描述
自定义,如“数据转发至Bcs Hyperledger Fabric增强版”。
数据来源
选择“设备属性”。
触发事件
自动匹配“设备属性上报”。
资源空间
选择“所有资源空间”。
- 单击“设置转发目标”页签,单击“添加”,设置转发目标,设置完成后单击“确定”按钮。
表4 创建转发目标参数说明 参数名
参数说明
转发目标
选择“区块链服务(BCS)-Hyperledger Fabric增强版”。
区域
选择数据上链的BCS Hyperledger Fabric增强版实例所在的区域。
实例
选择数据上链的BCS Hyperledger Fabric增强版实例。
通道
选择数据上链通道。即购买流程步骤4实例化链代码的通道。
接入组织
选择上链的身份组织。
背书组织
选择上链背书的组织,需要和链代码的背书策略保持一致才能正常上链。
链代码名称
填写上链所需要调用的链代码名称。即购买流程步骤3所安装的链代码名称。
链代码函数
选择上链需要调用的链代码函数。
参数配置
配置转发字段与调用链代码函数的参数下标的映射,转发字段可以参考设备属性上报通知。如设备Id:notify_data.header.device_id
图8 新建转发目标-转发至BCS-华为区块链Hyperledger Fabric
- 单击“启动规则”,激活配置好的数据转发规则。
三、验证操作
- 您可以使用配置设备接入服务时注册的真实设备接入平台,上报任意数据。
- 您也可以使用模拟器模拟设备上报数据,操作方法请参考在线开发MQTT协议的智慧路灯。
期望结果:
登录华为云区块链BCS控制台,在“实例管理 > Hyperledger Fabric增强版”实例列表中,找到数据上链的Hyperledger Fabric增强版实例,进入“区块链管理”界面,选择左侧“区块链浏览器”,切换到“对应通道”,在“交易列表”中可以看到最新上链的交易信息。