如何搭建以太坊私有链

发布时间:2022-01-18 10:42:16 作者:iii
来源:亿速云 阅读:163

这篇文章主要介绍“如何搭建以太坊私有链”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何搭建以太坊私有链”文章能帮助大家解决问题。

安装geth

下载离线安装地址:https://geth.ethereum.org/downloads/ ,选择对应的操作版本

初始化创世区块

创建工作区目录

如何搭建以太坊私有链

区块描述文件

文件结构语法采用json数据格式配置,genesis.json文件内容如下

{
    "config": {
        "chainId": 7777,
        "homesteadBlock": 0,
        "eip155Block": 0,
        "eip158Block": 0
    },
    "alloc": {},
    "coinbase": "0x0000000000000000000000000000000000000000",
    "difficulty": "0x20000",
    "extraData": "",
    "gasLimit": "0x2fefd8",
    "nonce": "0x0000000000000042",
    "mixhash": "0x0000000000000000000000000000000000000000000000000000000000000000",
    "parentHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
    "timestamp": "0x00"
}
config.chainId // 区块链的ID,在 geth 命令中的 --networkid 参数需要与 chainId 的值一致
config.homesteadBlock // Homestead 硬分叉区块高度,不需要关注
config.eip155Block // EIP 155 硬分叉高度,不需要关注
config.eip158Block // EIP 158 硬分叉高度,不需要关注
coinbase // 矿工账号,第一个区块挖出后将给这个矿工账号发送奖励的以太币
difficulty // 难度值,越大越难
extraData // 附加信息随便填
gasLimit // gas 的消耗总量限制,用来限制区块能包含的交易信息总和,因为我们是私有链,所以填最大
nonce // 一个 64 位随机数
mixhash // 与 nonce 配合用于挖矿,由上一个区块的一部分生成的 hash
parentHash // 上一个区块的 hash 值
alloc // 预设账号以及账号的以太币数量,私有链挖矿比较容易可以不配置
运行命令:

./geth --datadir ./privateChain/data0 init genesis.json

执行命名后在privateChain生产如下结构目录及文件

启动私链节点

./geth --identity "TestNode1" --datadir "./privateChain/data0" --rpc --rpcapi "db,eth,net,web3" --rpcaddr "127.0.0.1" --rpcport "8486" --port "30304" --networkid "7777" console

令的主体是geth console,表示启动节点并进入交互式控制台,--datadir选项指定使用data0作为数据目录,--networkid选项后面跟一个数字,这里是7777,表示指定这个私有链的网络id为7777。网络id在连接到其他节点的时候会用到,以太坊公网的网络id是1,为了不与公有链网络冲突,运行私有链节点的时候要指定自己的网络id。运行上面的命令后,就启动了区块链节点并进入了Javascript Console:只有console命令和attach命令会进入js交互窗口。

 使用命令 geth -h 可以查看geth 相关的帮助文档。这里我说几个常用的属性。

   --Identity : 节点身份标识,起个名字
   --datadir : 指定节点存在位置,“data0”
   --rpc : 启用http-rpc服务器
   --rpcapi : 基于http-rpc提供的api接口。eth,net,web3,db...
  --rpcaddr : http-rpc服务器接口地址:默认“127.0.0.1”
   --rpcport : http-rpc 端口(多节点时,不要重复)
   --port : 节点端口号(多节点时,不要重复)
   --networkid : 网络标识符 随便指定一个id(确保多节点是统一网络,保持一致)

如何搭建以太坊私有链

这是一个交互式的Javascript执行环境,在这里面可以执行Javascript代码,其中>是命令提示符。在这个环境里也内置了一些用来操作以太坊的Javascript对象,可以直接使用这些对象。这些对象主要包括:

eth.accounts:枚举系统中的账户; 
eth.getBalance():查看账户余额,返回值的单位是 Wei(Wei 是以太坊中最小货币面额单位,类似比特币中的聪,1 ether = 10^18 Wei);
eth.blockNumber:列出区块总数; 
eth.getTransaction():获取交易; 
eth.getBlock():获取区块
admin.addPeer():连接到其他节点 
admin.nodeInfo.enode 查看本节点enode

miner.start():开始挖矿;

miner.stop():停止挖矿

personal.newAccount():创建账户;

personal.unlockAccount():解锁账户 以太坊的一个保护机制,每隔一段时间账户就会自动锁定

txpool.status:交易池中的状态;

web3.fromWei():Wei 换算成以太币;

web3.toWei():以太币换算成 Wei;

向本节点添加其他P2P节点信息

查看节点信息

添加在同一个创世链上节点
admin.addPeer("enode://2f86dbb18242371fa0a8e7098cb13a012ad9d8ee80f0bbba94a798b16d3c6c3c247d3e333b8da27a591b38365f927a25359376d4bf38575bb0371a1365294f91@[::]:30301?discport=0")

注意:当连接同一个网络中的其他节点时,使用的就是上面的第一个字段enode的值。

按照如上操作,可以建立并形成一个私链去中心化的集群。任意一个节点挖矿,挖到区块之后,都会同步到其他的两个节点。如果genesis.json文件不相同或者networkid不相同时,都不能添加成功。genesis.json不同,将会生成不一样的创世区块,networkid不同就是两个不同的网络,自然就不能添加成功。

关于“如何搭建以太坊私有链”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

推荐阅读:
  1. 第一行代码:以太坊(1)-创建自己的私有区块链
  2. 如何搭建linux及ubuntu以太坊私有链开发环境

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

以太坊

上一篇:Kademila协议P2P索引算法的知识点有哪些

下一篇:Apache Pulsar在BIGO的性能调优实战是怎样的

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》