关于代码介绍方法,可以去看我的博客。里面介绍了一些功能的实现思路和方法,以及使用到的一些库的介绍。
首先在maven中更改jar包生成位置
然后使用命令生成jar包
mvn package
在IDEA运行着将第二块区域进行注释(第一块区域不要注释),使用jar包运行则将第一块区域进行注释(第二块区域不要注释)
java -jar 包名 ip地址 端口号 序号 文件保存位置
- ip地址和端口号代表节点作为server需要占用ip和端口号
- 序号:节点的序号,必须独一无二
- 文件保存位置
例如:
java -jar oldpbft-jar-with-dependencies.jar 127.0.0.1 8080 0 C:\\Users\\XiaoHui\\Desktop\\data\\
因此,你可以在本机上运行多个节点(保证端口号和序号不同即可)。
首先配置启动,允许多个main执行
然后,每次启动一个节点,更改 i
就可以启动不同的节点。
int i = 0;
String ip = "127.0.0.1";
int port = 8080 + i;
StartConfig.basePath = "C:\\Users\\XiaoHui\\Desktop\\data\\";
int index = i;
-
程序会自动新建一个json文件,里面保存节点的ip信息,
StartConfig.basePath
代表json文件保存位置。 -
如果结束所有节点,然后重新启动程序,需要将
ip.json
中的内容全部删除。(比如说你启动了1节点,2节点,然后你关闭了这个程序,又想重新启动1节点2节点就必须删除),否则会报错,如下图所示: -
只有主节点能够发送消息,其他节点会发送消息失败。如何想使用非主节点发送消息,可以去修改代码。如下图所示:将红框内的代码注释即可。
实际上代码完成的功能很少很少,就是完成了PBFT中的节点加入功能,然后还有消息发送PBFT认证功能,以及交易数据保存的功能**<只写了函数,需要自己去调用>**。其他的就emm没有做。本人对区块链也不是特别的了解,所以有些功能感觉实现起来的代码怪怪的。
这个仓库代码大概率不会进行更新了,因为emmmmmm,考研去了。
考研结束,重新更新一波。