geth搭建私有链及遇到的一些问题

安装好geth后开始搭建私有链

  • 创建网络的“创世”(genesis)状态,写在一个 JSON 文件里

    一开始写的JSON文件如下:

{
“config”: {
“chainId”: 15
},
“difficulty”: “2000”,
“gasLimit”: “2100000”,
“alloc”: {
“7dh9a875a174b3bc565e6424a0050tbc1b2d1d82”: { “balance”: “300000” },
}
}

比较奇怪的是初始化这个创世区块后,无法由一个账户转账到另一个账户,交易可以发出,但是不会被打包进区块里。后来修改了gasLimit为0xffffffff,再发送交易时发现,交易发送失败,提示信息为交易肯定无法被打包进区块中。猜测可能是发送交易给的gas不够,但是按理来说在私链里是不在乎gas的。希望有人能解释一下…

后来换成了geth官方提供的JSON文件,能正常发送交易:

{
“config”: {
“chainId”: 123,
“homesteadBlock”: 0,
“eip150Block”: 0,
“eip155Block”: 0,
“eip158Block”: 0,
“byzantiumBlock”: 0,
“constantinopleBlock”: 0,
“petersburgBlock”: 0,
“istanbulBlock”: 0
},
“alloc”: {},
“coinbase”: “0x0000000000000000000000000000000000000000”,
“difficulty”: “0x2000”,
“extraData”: “”,
“gasLimit”: “0x2fefd8”,
“nonce”: “0x0000000000000042”,
“mixhash”: “0x0000000000000000000000000000000000000000000000000000000000000000”,
“parentHash”: “0x0000000000000000000000000000000000000000000000000000000000000000”,
“timestamp”: “0x00”
}

  • 初始化创世区块

geth --datadir (指定的目录 .表示当前目录) init genesis.json

  • 启动私链

geth --datadir 制定的目录 --networkid 123
这里的networkid是JSON文件里的chainid

这样就创建了一条私链

如果要进行交互,可以进入控制台,在启动命令后加上 console

geth --datadir data --networkid 15 console

如果想让数据在日志踪显示,可以再加上2>output.log

geth --datadir data --networkid 15 console 2>output.log

可以使用以下命令进行操作

  • 添加账户

personal.newAccount(“111111”) -111111表示密码

  • 查看现有账户

eth.accounts

  • 查看余额

eth.getBalance(eth.accounts[0])

  • 查看现有区块

eth.blockNumber

  • 启动/停止挖矿

miner.start(1)
miner.stop()

  • 转账

eth.sendTransaction({from:eth.accounts[0],to:eth.accounts[1],value:3000000000000000000})

注意:转账前需要先解锁被转账的账户

personal.unlockAccount(eth.accounts[0])

注:发送交易后发现,发送者需要提供ether,数值为21000000000000 Wei

  • 获得区块信息

eth.getBlock(1)

  • 数值转换

将Wei转换为ether
web3.fromWei(100000000000000,‘ether’)

将ether转换为Wei
web3.toWei(10,‘ether’)

PoA:
以上挖矿过程是基于PoS的,如果觉得这样不稳定或太慢,可以改成基于PoA挖矿,命令如下(此时不需要创世区块)

geth --datadir 制定的目录 --dev console 2>output.log

在eth.accounts里会有一个初始的用户(developer account),该账号默认解锁,会自动挖矿,每当有交易生成时,便会生成一个区块。

遇到的问题:
进入控制台后,一直不停输出

INFO [04-11|11:30:24.205] Looking for peers peercount=0 tried=44 static=0

还没弄清楚这是什么意思

你可能感兴趣的:(geth搭建私有链及遇到的一些问题)