Geth私链的多节点运行「建议收藏」

2022-11-09 15:00:57 浏览数 (1)

前一阵分别介绍了在Ubuntu和CentOS下搭建基于Geth的以太坊私链,这篇文章介绍如何搭建Geth多节点的运行。

提示:在Ubuntu和CentOS下搭建以太坊私链,请参考《在Ubuntu下使用Geth搭建自己的以太坊私有链》和《CentOS7下安装Geth,搭建以太坊私有链》

一、在Windows下安装Geth

为了方便测试,我在Windows下搭建了一个套Geth环境。安装方法比较简单,在官网 https://geth.ethereum.org/downloads/ 下载相应的安装文件,格式为exe,直接安装就可以了。我的操作系统是Windows 10专业版,安装的Geth版本为1.9.2。安装过程中如果杀毒软件报毒,请忽略。

安装完后执行cmd,打开控制台窗口,执行如下命令:

代码语言:javascript复制
geth version

返回如下结果,表示安装成功:

二、使用remix验证私链

我们自己创建的私链是否能用呢?可以使用remix验证一下。

  • 准备工作

首先使用RPC通信方式启动私链,并在私链上创建一个用户,挖矿,确认新建的账户下有余额。

提示:具体启动私链,创建账户以及挖矿等操作,请参考《在Ubuntu下使用Geth搭建自己的以太坊私有链》

  • 验证私链

在浏览器输入http://remix.ethereum.org,打开remix IDE。在左侧工具栏选择 Deploy & run transactions

然后在 Environment 中选择 Web3 Provider

在弹出框上点击OK,然后在输入框中输入本机的IP地址,通常使用默认的localhost和8545即可。

点击OK后,在左侧就可以看到私链上的账号以及账号对应的余额了。

三、多节点运行

这一节,我利用以前在Linux下创建的Geth节点和刚创建的Windows节点建立连接,实现多节点运行。

多节点运行需要注意以下几点:

  • 多节点运行要使用rpc通信方式启动私链。同时启动参数中的 nodiscover 参数很重要,它可以避免后启动的节点被先启动的节点自动扫描到,而必须由我们手动去添加节点
  • 必须使用相同的JSON配置文件初始化创始区块
  • rpcport 和 port参数必须和第一个不同
  • 启动节点

首先,分别启动两个节点,然后查看两个节点下的连接节点信息。

Linux连接节点信息如下:

Windows连接节点信息如下:

  • 添加节点

在Linux下添加Windows节点。两个节点只要有一个节点主动建立连接关系即可,另一个节点会自动获取连接关系。首先在Windows执行查看节点信息命令:

代码语言:javascript复制
> admin.nodeInfo.enode

然后将返回结果的字符串复制下来,在Linux下添加节点时会用到:

在Linux节点上执行添加节点命令:

代码语言:javascript复制
> admin.addPeer()

返回true,表示添加成功

需要注意的是,由于两个节点不在同一台机子,所以执行addPeer函数时,参数字符串最后的IP地址和端口号必须是另一个节点的IP和启动端口。因为我的Linux节点安装在虚拟机上,这里我的IP是局域网地址 192.168.0.122,端口是节点启动的 port 参数指定端口 30305。

这时再分别查看两个节点下的连接节点信息,就会看到发生了变化。

Linux下的连接节点信息:

Windows下的连接节点信息:

这时,Windows节点启动挖矿,Linux节点的Log文件会有输出:

提示:需要注意的是,我的Windows节点在挖矿时,Linux节点会出现无法同步的错误,且会自动删除连接节点的信息,待Windows节点停止挖矿后,过一会自动恢复。排查后发现是由于两个系统时间不同步引起的。这个问题不知道在物理机上创建多节点环境会不会出现,大家可以注意下。

四、不同节点进行转账

这时我们可以参考《在Ubuntu下使用Geth搭建自己的以太坊私有链》文章中转账一节的方法,从Windows节点转账给Linux节点下的某个账户。我这里是从Windows节点下的第一个账户转账给Linux节点下的第二个账户。

执行转账操作并启动挖矿后,我们可以看到Linux节点下第二个账户的余额发生了变化:

提示:在Windows下转账时,需要先解锁账户。新版本的Geth出于安全考虑,默认禁止了HTTP通道解锁账户,相关issue:https://github.com/ethereum/go-ethereum/pull/17037。要解决此问题,可在启动参数中增加 –allow-insecure-unlock 。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/184618.html原文链接:https://javaforall.cn

0 人点赞