配置高可用性
如果服务链中只使用一个网桥,该网桥就会成为单点故障。 为了解决这个问题,我们将介绍如何使用两个或更多网桥构建 HA 系统。 如下图所示,将网桥配置为至少两对连接,这样即使其中一个网桥连接出现问题,数据锚定和链之间的价值传输仍可通过另一个网桥正常进行。
先决条件
- EN 的主桥和 SCN 的副桥相连。 如果不是,请参考 Kairos connection建立连接。
- 本节将介绍如何在 Kairos 和 ServiceChain 之间添加额外的桥接器。 同样,您也可以通过添加另一个网桥来设置 HA。
步骤 1:在 EN-SCN 之间添加另一个网桥
在连接到 Kairos中,我们假设 EN 和 SCN 分别以 EN-01 和 SCN-L2-01 的桥接方式连接。 在本节中,我们将在 EN-02 和 SCN-L2-02 之间添加另一座桥梁。 由于程序相同,我们将作简要说明。
构建 EN-02 后,在 conf/kend.conf
中将 SC_MAIN_BRIDGE
设置为 1,然后在 EN-02 上重启 ken。
SC_MAIN_BRIDGE=1
通过以下命令检查 EN-02 的 KNI 信息:
EN-02$ ken attach --datadir ~/data> mainbridge.nodeInfo.kni"kni://eb8f21df10c6562...25bae@[::]:50505?discport=0"
登录 SCN-L2-02,使用 EN-02 的 KNI 创建main-bridges.json
。 请确保它应该是带方括号的 JSON 数组格式。
SCN-L2-02$ echo '["kni://eb8f21df10c6562...25bae@192.168.0.5:50505?discport=0"]' > ~/data/main-bridges.json
在 SCN-L2-02 的外壳上,按以下说明编辑 kscn-XXXXX-amd64/conf/kscnd.conf
。
要连接桥接器,请将 SC_SUB_BRIDGE
设置为 1。
SC_PARENT_CHAIN_ID "设置为 Kairos 的 "chainID "1001。
SC_ANCHORING_PERIOD "是一个参数,用于决定向父链发送锚定事务的周期。 在这个例子中,每 10 个子区块就会向父链(Kairos)提交一个锚交易。
...SC_SUB_BRIDGE=1...SC_PARENT_CHAIN_ID=1001...SC_ANCHORING_PERIOD=10...
如果在 EN-02 上重新启动 ken,EN-02 和 SCN-L2-02 之间将自动连接桥接,数据锚定将从连接点开始,如下图所示。
在 EN-02 和 SCN-L2-02 之间添加桥接器后,可以看到节点之间的连接已建立,如下图所示。
第 2 步:注册和订阅桥接合同
如上图所示,桥接合同只在 EN-01 和 SCN-L2-01 中登记。
连接 SCN-L2-02 控制台,运行用于网桥注册、网桥订阅和令牌注册的 API。 在跨链价值转移 第 2 步中部署带有 EN-01 和 SCN-L2-01 的桥接合约时,创建了桥接合约和代币合约。
$ kscn attach --datadir ~/data> subbridge.registerBridge("0xCHILD_BRIDGE_ADDR", "0xPARENT_BRIDGE_ADDR")null> subbridge.subscribeBridge("0xCHILD_BRIDGE_ADDR", "0xPARENT_BRIDGE_ADDR")null> subbridge.registerToken("0xCHILD_BRIDGE_ADDR", "0xPARENT_BRIDGE_ADDR", "0xCHILD_TOKEN_ADDR", "0XPARENT_TOKEN_ADDR")null
在桥梁合同中,应更新有关增加一座桥梁的信息。 在 service-chain-value-transfer-example 的 erc20/erc20-addOperator4HA.js
文件中写入新增额外桥接器的子操作符和父操作符信息,并执行 node erc20-addOperator4HA.js
。
// register operatorawait conf.child.newInstanceBridge.methods.registerOperator("0xCHILD_BRIDGE_ADDR").send({ from: conf.child.sender, gas: 100000000, value: 0 });await conf.parent.newInstanceBridge.methods.registerOperator("0xPARENT_BRIDGE_ADDR").send({ from: conf.parent.sender, gas: 100000000, value: 0 });
当有多个桥接器时,可以通过设置阈值来更安全地进行价值转移。 只有当阈值以上的操作员正常请求数值转移时,才能启用数值转移。 例如,在当前示例中,如果有两个桥接器对,阈值设置为 2,则只有当两个桥接器对都正常请求时,才能进行数值传送。 也就是说,即使一座网桥受到攻击并发送了异常请求,也可以阻止它。 阈值的默认值为 1。 在 service-chain-value-transfer-example 的 erc20/erc20-addOperator4HA.js
文件中,取消注释下面的代码并设置阈值,然后运行它以更改桥接合约的阈值。
// // set threshold// await conf.child.newInstanceBridge.methods.setOperatorThreshold(0, "your threshold number").send({ from: conf.child.sender, gas: 100000000, value: 0 });// await conf.parent.newInstanceBridge.methods.setOperatorThreshold(0, "your threshold number").send({ from: conf.parent.sender, gas: 100000000, value: 0 });
注册完成后,如下图所示,将在 EN-02 和 SCN-L2-02 中注册桥接合同,以配置 HA。
当两个或更多桥对连接用于 HA 时,同一区块的数据锚定事务会发生多次,价值转移事务也会发生多次。 也就是说,需要额外付费。