引言
本文首先介绍在Rococo本地的测试流程,最后介绍rococo线上测试parachain的流程
Rococolocaltestnetwork中测试parachain
StartRelaychain(LocalRococorelaychain)
准备rococo-local-cfde.json
以下命令是在polkadot目录下操作的,这里切换分支到v0.9.16,然后编译cargobuild--release
编译完成后,在polkadot目录下执行:
启动parachain
生成parachain的chainspec
如果需要修改paraId,可以修改rococo-local-parachain-plain.json文件
Dora Factory启动KSM平行链代币迁移:4月3日消息,Dora Factory Kusama平行链租约在UTC时间2023年4月17日到期,将1:1迁移所有DORA-KSM链上token至以太坊主网。此次迁移使得DORA-KSM持币用户可以接触以太坊DORA的流动性,并且得以参与到广泛的DORA社区活动和token使用场景中。Dora Factory Kusama平行链上的持币用户需要在14天内完成以太坊地址注册工作。[2023/4/3 13:42:01]
这里修改为:2052
生成修改后的paraId的chainspec文件
生成wasm文件
Bifrost已成功续约Kusama平行链槽位:据链上数据显示,Bifrost已于5月2日续拍到租期为21-28 Kusama平行链槽位。Bifrost Kusama平行链将与未来Bifrost Polkadot平行链成功竞拍后被同时保留,服务于两个生态。
待Kusama Polkadot跨链桥成熟后,Bifrost计划将主要协议及治理模块迁移至Bifrost Polkadot平行链,通过XCM跨链治理Bifrost Kusama平行链,支持Kusama生态设施。[2022/5/2 2:45:42]
生成genesisstate文件
启动本地collator节点
然后在打开本地的relaychain的polkadot-js的前端界面,注册parachain,上传Wasm和genesisstate参考:https://docs.substrate.io/tutorials/v3/cumulus/connect-parachain/
Dora Factory将参与4月3日开始的新一轮Kusama平行链拍卖:3月27日消息,据官方消息,DAO-as-a-Service基础设施Dora Factory将参与从4月3日开始的新一轮Kusama平行链拍卖。[2022/3/27 14:20:26]
Rococolivetestnetwork中测试parachain
比如,上面我们已经注册了parachain2052,那么我们就可以在rococo公开测试网上测试我们的Parachain了。
步骤:
1.在rococopublictestnetwork注册一个paraId
2.通过这个ParaId以及之前我们本地生成的genesisstate和wasm文件来注册parathread
3.当注册成为一个parathread后,我们可以看到parathread处于onboarding状态。此时,我们就可以申请成为平行链了,可以联系Parity官方的人进行操作,在element频道
ZT支持波卡平行链插槽拍卖:据官方公告,ZT将于11月6日21:00(UTC+8)启动“飞鸽计划”以支持波卡平行链插槽拍卖。 一旦竞拍成功,用户可以以1:1的比例获得ZDOT。[2021/11/6 6:35:58]
4.如果官方的人将Parathread升级为parachain后,我们就可以开始本地启动平行链进行测试,是否能链接到rococolive且正常出块。
首先,启动Live模式的parachain,这里有两种方式:
第一种:修改parachain链的chainspec文件,以命令行的方式进行指定Live启动
第二种:通过json文件的形式,由于我们之前已经在本地生成了rococo-local-parachain-2052-raw.json这个文件,我们只需要修改其中的一些参数
主要修改字段为:
chainType:需要将Local修改为Live,
relay_chain:修改为rococo
波卡发布Kusama和平行链稳定报告:存在网络确定性停顿问题但总体运行平稳:8月17日,在波卡(Polkadot)发布的Kusama和平行链稳定报告中,结合平行链出块稳定性、批准投票(ApprovalVoting)、网络连接以及负载(CPU和网络)四个关键因素得出结论,目前网络运行平稳,唯一的主要问题是网络偶尔遇到的确定性停顿(finalitystall)问题,不过由于这些停顿被故障保护装置捕获,因此没有造成太大损害,目前正在调查根本原因,将在平行链在波卡上启动之前给出解决方案。[2021/8/17 22:20:00]
para_id:需要与我们在rococolive上注册的parachainId保持一致
其他的字段看自己需要进行修改,也可不修改
这里值得一提的就是bootNodes字段,这个字段在自己首次本地启动的时候无需进行配置,但是如果你的平行链已经上线并且需要给其他用户加入的话,这里就需要进行配置引导节点。
获取当前需要连接的rococolive的chainspec文件
笔者此时的rococolive的runtime版本为polkadot-v0.9.16,所以我们从polkadot上获取到rococo的chainspec文件,放在我们的parachain目录下
注意,我们的parachainlive的runtime版本必须要和当前rococolive的版本一致
一切准备就绪后,我们就可以启动我们本地的平行链,准备连接到rococolive进行parachain出块测试了
注意,下面的basepath我们需要预留至少12G的空间(以当前时间为2022-02-20来计算的话),否则空间不够拉取rococo的区块
在启动上述命令后,我们可以看到Log里会同步rococo的区块,整个过程大概耗时2小时左右,等待全部同步完毕后,我们的Parachain就会正常出块了~。
查看rococotestnetwork可以看到:
打开本地8844端口可以看到parachain已经可以正常出块了,这里我已经出到204个块.....
至此,rococolive测试结束~
Rococolive部署注意事项:
1.如果出现以下问题:
这种是由于使用的rococolive的json文件和当前rococolive版本不一致导致的,比如使用的是polkadot-0.9.13的live文件,然而当前rococolive版本为polkadot-v0.9.16
2.同步中继链区块错误:
这里是由于我们liveParachain的版本和rococlive不一致
3.在将pallet版本从polkadot-v0.9.13升级到polkadot-v0.9.16时,出现一些pallet宏功能无法使用问题
palletStruct的宏问题
当前polkadot-v0.9.16版本中,Pallet结构体上需要加上#
palletstorage问题
当前polkadot-v0.9.16版本中,我们在使用StorageMap这个存储结构的时候,如果我们的存储结构中涉及到AccountId需要使用OptionQuery的方式,而非之前的ValueQuery,因为在官方移除了对于AccountId的default处理,所以我们就需要使用Option的方式处理空值None。对应的咱们的pallet就需要进行重构,并对None进行处理,杜绝Runtime出现这种异常。
4.在同步rococolive的区块时,出现以下错误,并且可以看到一直拉取不到最新的区块
这里是由于本地机器时间不同步,使用ntp同步即可
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。