node.js - 使用 fabric-sdk-node v2.1 实现事务提交监听器
问题描述
我目前正在使用版本2.1
并fabric-sdk-node
尝试在应用程序中使用Network.addCommitListener()
函数实现事务提交侦听器,但是在提交事务以供背书后我无法接收任何事件。
为了实现这一点,我使用了以下代码:
var listener = (error, event) => {
if (error) {
// Handle peer communication error
}
else {
// Handle transaction commit event
}
};
const peers = network.channel.getEndorsers();
await network.addCommitListener(listener, peers, txId);
该listener
对象似乎存在一些问题,因为根据官方文档,侦听器对象的类型定义为CommitListner
,但无法弄清楚如何在我的解决方案中实现它。任何帮助,将不胜感激。
解决方案
如果您只想接收来自网络中所有对等方的提交事件,那么您可以通过简单地使用NETWORK_SCOPE_ALL_FOR_TX
默认事务事件处理程序来实现这一点。其他一切都由您负责,Transaction.submit()
只有在从所有可联系的对等方收到提交事件后,所有调用才会返回。
如果您想实现自己的自定义提交等待逻辑而不是使用默认实现之一,您应该实现自己的事务事件处理程序。这将在提交流程中的适当时间被调用并传递您需要的信息。
本页详细介绍了上述两种方法,包括本页底部的示例事务事件处理程序实现(使用提交侦听器)的链接:
最后一种方法,我建议仅用于更高级的场景,您确实需要将事务提交为即发即弃并异步管理您自己对事务提交事件的处理,即在调用之前获取事务 ID 并附加一个提交侦听器提交以确保您不会错过事务提交事件。然后应该使用NONE
事务事件处理程序执行提交,以便在事务成功发送到订购者后立即返回。这需要至少 2.1.1 版的fabric-network,其中引入了在调用提交之前获取事务 ID(并覆盖每个事务的默认事务事件处理程序)的能力。
上述所有模式在 v1.4 版本中也应该是可能的,但事件监听 API 略有不同。有关更多详细信息,请参见此处:
推荐阅读
- java - 在 spring-cloud-gateway 中的 .route() 方法中使用 uri() 方法两次
- javascript - 如果打印控制台日志是正常的。但执行是空的
- reactjs - 在firebase中添加一个集合文档长度的计数器
- google-cloud-platform - 使用“Google Cloud Platform”部署管理器设置 LAMP,是否可以使用 Cloud Shell 进行编辑?
- r - 计算列表的相似度分数
- c++ - 通过移动 Slider 在 qt 中撤消 setPixel 操作
- ios - 无法在 UserDefaults 中存储自定义类 - 尝试插入非属性列表
- ssis - 事实表核对或验证
- reactjs - 如何将 create-react-app 用于带有 TypeScript 的 React 版本 16.xx?
- c# - 如何使用 .net 在 Amzon 中使用 sell-partner-api 加密和上传数据