隐藏错误的最佳方法是什么?
我想摆脱此错误(将其隐藏,或者如果有人知道问题出在哪里,则可以更好地解决):
2019-12-12T17:43:54.626Z - error: [Orderer.js]: sendBroadcast - on error: "Error: 2 UNKNOWN: Stream removed\n
at Object.exports.createStatusError (/home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/common.js:91:15)\n
at ClientDuplexStream._emitStatusIfDone (/home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/client.js:233:26)\n
at ClientDuplexStream._receiveStatus (/home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/client.js:211:8)\n
at Object.onReceiveStatus (/home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/client_interceptors.js:1306:15)\n
at InterceptingListener._callNext (/home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/client_interceptors.js:568:42)\n
at InterceptingListener.onReceiveStatus (/home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/client_interceptors.js:618:8)\n
at /home/hl-root/fabric-samples/fullgear-4node-setup/app/node_modules/grpc/src/client_interceptors.js:1123:18"
Transaction submitted
我的代码如下:
while {
try {
const gateway = new Gateway();
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
const network = await gateway.getNetwork('mychannel');
const contract = network.getContract('chaincode');
await contract.submitTransaction('createTransaction', 'Transaction3', '1');
console.log('Transaction submitted');
}
catch (error) {
console.error(`Failed to submit transaction: ${error}`);
process.exit(1);
}
}
我得到了错误,但是指令发出了并且我得到了日期(所以catch错误永远无法解决?)
答案 0 :(得分:0)
您的问题是network.getContract返回一个Promise,所以这里发生的事情是您的代码在Promise解析之前就已通过该行,因此您的try / catch在抛出错误之前完成,因此是异常。试试这个:
while {
try {
const gateway = new Gateway();
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
const network = await gateway.getNetwork('mychannel');
const contract = await network.getContract('chaincode');
await contract.submitTransaction('createTransaction', 'Transaction3', '1');
console.log('Transaction submitted');
}
catch (error) {
console.error(`Failed to submit transaction: ${error}`);
process.exit(1);
}
}