对百度超级链Xuper使用过程中的进一步理解

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 对百度超级链Xuper使用过程中的进一步理解

前言


之前写过一篇文章,在百度超级链Xuper上部署智能合约并实现存证功能这里叙述了 搭建3个节点 将节点1作为出块节点,这篇文章 咱们配置下将 节点1和节点2作为出块节点,节点3作为同步节点 如何配置以及需要注意的几点,以免读者在操作实践的时候入坑或者由于理解不透彻导致耽误很多时间.


我对百度链使用时间不长,可能理解的比较片面,我写这篇浅文,就当抛砖引玉吧,希望大佬前辈们指出错误的地方或者有其他需要探讨的地方 欢迎发送到我的邮箱(pingfanrenbiji@163.com) 咱们交流下吧


配置多个出块节点


将节点1和节点2配置为出块节点
节点3作为同步节点


修改节点1的配置


  • 查看节点2的地址


cd pn2
cat data/keys/address
WJHuX9haAL7Sea6rUo8VBhhsQmMJbTopk


  • 配置到节点1的xuper.json中


image.png


  • 删除配置项
将 init_proposer_neturl 配置项删除


将节点1的配置复制到节点2和节点3


cp pn1/data/config/xuper.json pn2/data/config/xuper.json
cp pn1/data/config/xuper.json pn3/data/config/xuper.json


启动每一个节点


先删除节点下面的 data/blockchain/xuper 文件夹
./xchain-cli createChain
nohup ./xchain --vm ixvm &


确认下节点2是否在出块


cd pn2
tail -f logs/xchain.log|grep 'isCoreMiner=true'


思考:每次修改配置都要删除数据吗


  • 如果修改共识算法的话 可以动态配置


通过发起提案的方式
官方文档
https://xuperchain.readthedocs.io/zh/latest/advanced_usage/initiate_proposals.html
每次访问这个文档都很慢 有没有快速访问的方法?


  • 如果增加一个出块节点


有动态添加节点的接口,所以不用重做数据
另外 节点刚加入的时候是先同步数据再出块的


  • 修改其他配置


需要重做数据(这一点没有公司能够容忍吧,修改一个配置,就需要把之前的历史数据删除掉 然后重新整数据)


关于合约部署这块 出现签名错误的原因和解决方法


javasdk关于连接节点环境


image.png


  • 第一个圈红的地方是一个ip和port 这个地址可以是多节点环境中的任何一个节点 这里可以做负载均衡


比如有3个节点 通过nginx做负载均衡 
所以这里配置的是nginx的ip和port(这一点我没有实践 猜想是可以的)


  • 关于第二个圈红的地方 keys 表示 读取的是 resources文件夹下面的keys文件夹下面的private.key私钥文件


关于这个私钥文件它是一个节点账户
这里咱结合实际使用过程来说明下这里的注意点


a、连接节点环境并读取keys文件夹下面的私钥文件获取账户信息


b、部署合约


./xchain-cli wasm deploy --account XC1111111111112222@xuper --cname eleccertest1  -a '{"creator": "someone"}' -A data/acl/addrs -o tx.output --name xuper -H localhost:37101 /Users/mengfanxiao/Documents/project/company/XinPools_INFO/document/business/baidu/xuperchain/data/blockchain/xuper/wasm/eleccert --fee 5568187 --runtime=go -a '{"owner":"mengfanxiao"}'
此时如果报错
Failed to post tx:TX_SIGN_ERROR
这说明没有获取到当前账户的私钥文件,因为做交易的时候 需要获取操作账户的私钥信息进行签名 那么为什么没有获取到私钥文件呢?
首先看下执行当前命令所使用的客户端是哪个节点 比如 节点3
然后再看 当前连接的节点是哪个节点 -H localhost:37101 这个是节点1
使用节点3的客户端连接节点1的服务是可以的 关键节点3 data/keys/下面是否有XC1111111111112222@xuper 这个合约账户的
私钥文件 data/keys/ 目录下是否具有该合约账户的私钥文件


acl 多签这块


官方文档 
https://xuperchain.readthedocs.io/zh/latest/advanced_usage/contract_accounts.html
acl多签交易时使用的,如果不需要多签名,不需要关注这一块



操作日志 未同步这块


比如 上面的 部署合约的命令 如果执行报错 会有一个日志编号
拿着日志编号去对应的节点服务下面的日志文件中查看具体的错误信息
比如上面连接的是 -H localhost:37101 是节点1 ,那么只需要去节点1
下面的日志去找下该日志编号对应的详细日志即可


定时出块的优势和劣势


关于这一点 我说的也不够专业 并且我对百度超级链使用的时间比较短 研究的还不太深入 所以我只能说下 目前的想法 就当作抛砖引玉吧
先说下使用场景吧 然后针对使用场景里面的问题具体阐述下
先来类比下比特币
首先比特币在公网有一条root链,全世界的交易都发生在该链上,自己在本地启动一个比特币的客户端,都会先同步下root链上的交易,然后自己发起的交易,也会上到root链上,然后在同步给其他的交易端
然后在看下搭建百度链的过程
A公司在自己的服务器上搭建了4个节点,节点环境搭建好之后,咦?怎么在一直不断的在出块?我自己的服务器内网里面还没有交易上链,怎么一直不断的在出块呢?不是应该同步下公网联盟链上的节点数据嘛?然后才意识到百度超级链是定时出块的,每个3秒就会出现一个块,无论有没有交易,都会出块
由此咱分析下有哪些劣势
劣势:
1、仅仅是公司内部范围内使用的数据 并没有其他公司的数据 使用的范围比较小,即先搭建一个root链,然后在加入的节点才会同步root链上的数据,而不是想其他的区块链一样 比如比特币 公网上已经有一条包含全世界交易的root链了,然后自己启动一个客户端,会先同步所有的数据
2、无论有没有交易都在定时出块,那么就会累计到很高的高度,但在业务量比较少的情况下 就会产生大量的空交易的块
3、既然产生大量的空交易的块 那么通过区块高度差值来做区块确认是否合理有待商榷
因为一般的话 确认链有2种方式
a、通过当前区块后面追加的区块的数据 如果追加了6个区块 即当前区块和最新区块之间的高度差 如果超过6个 就认为当前区块确认上链了
b、通过时间戳 查询当前区块的交易时间戳和当前时间差 超过一定的数值也认为是确认上链了
4、一旦配置错误 需要修改配置的话 那么之前积累的数据都需要先清空 这一点也是任何公司都不能够容忍发生的事情 ,所以第一次配置需要很谨慎


相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
8月前
|
Docker 容器 Perl
云效flow构建docker镜像更换apt源为阿里镜像源
在 Dockerfile 中添加命令以更换 Debian 源为阿里云镜像,加速容器内软件包下载。核心命令通过 `sed` 实现源地址替换,并更新 apt 软件源。其中 `cat` 命令用于验证替换是否成功,实际使用中可删除该行。
1621 32
|
存储 SQL 监控
【EMQX】EMQX管理控制台即EMQX Dashboard简介
【EMQX】EMQX管理控制台即EMQX Dashboard简介
1103 0
|
Unix Linux Go
Linux 使用Yum安装Go和配置环境
Linux 使用Yum安装Go和配置环境
|
Java
把javafx项目打包成exe文件详细过程
本文简化了将JavaFX项目打包成exe文件的过程,首先通过Idea将项目打包成jar包,然后使用GraalVM的native-image工具将jar包编译成exe文件,并展示了执行命令和运行结果。
858 0
把javafx项目打包成exe文件详细过程
|
存储 缓存 监控
【JVM调优】如何进行JVM调优?一篇文章就够了!
深入解读JVM性能的监控、定位和调优方案,阐述jps/stat/jstack、MAT等常用性能分析工具的使用,提出JVM参数、内存溢出、内存泄漏、CPU飙升、GC频繁等实际场景下JVM调优的方案。
4082 16
【JVM调优】如何进行JVM调优?一篇文章就够了!
|
移动开发 JavaScript 开发工具
微信浏览器内 h5 直接唤醒 app 之 微信开放标签 wx-open-launch-app
微信浏览器内 h5 直接唤醒 app 之 微信开放标签 wx-open-launch-app
|
存储 人工智能 数据处理
阿里云CTO周靖人:全面投入升级AI大基建
9月19日,在2024杭州云栖大会上,阿里云CTO周靖人表示,阿里云正在围绕AI时代,树立一个AI基础设施的新标准,全面升级从服务器到计算、存储、网络、数据处理、模型训练和推理平台的技术架构体系,让数据中心成为一台超级计算机,为每个AI和应用提供高性能、高效的算力服务。
23385 15
|
人工智能 架构师 IDE
阿里云通义灵码重磅升级,能自主修BUG、开发应用的AI程序员来了
通义灵码AI编程能力再进化,说几句话就能开发网页
23543 9
|
Java 编译器
Java中可变长参数的使用代码和方法
Java中可变长参数的使用代码和方法
177 7
|
Ubuntu Linux 网络安全
ubuntu linux通过rclone 挂载onedrive 到本地磁盘
ubuntu linux通过rclone 挂载onedrive 到本地磁盘
799 2