前提条件:Geth配置时,创建了一个账户,之后使用非开发者模式开启,开启命令如下:
geth --datadir ./data --networkid 108 --port 30303 --http --http.addr 0.0.0.0 --http.vhosts "*" --http.api "db,net,eth,web3,personal" --http.corsdomain "*" --snapshot=false --allow-insecure-unlock console 2>1.log
之后exit退出,然后使用开发者模式开启进入,命令如下(只多了粗体字部分):
geth --datadir ./data --networkid 108 --port 30303 --http --http.addr 0.0.0.0 --http.vhosts "*" --http.api "db,net,eth,web3,personal" --http.corsdomain "*" --snapshot=false --allow-insecure-unlock --dev --dev.period 1 console 2>1.log
执行命令后,会发现如下错误:
[root@localhost rungeth]# geth --datadir ./data --networkid 108 --port 30303 --http --http.addr 0.0.0.0 --http.vhosts "*" --http.api "db,net,eth,web3,personal" --http.corsdomain "*" --snapshot=false --allow-insecure-unlock --dev --dev.period 1 console 2>1.log
Fatal: Failed to unlock developer account: could not decrypt key with given password
[root@localhost rungeth]#
原因:这是因为刚才创建了账号,而在 dev 模式下,启动节点后,系统默认提供一个开发者账号,并且这个账号密码是空;
解决:清除掉所有的信息,就是把data目录删除即可,同时也可以把日志文件删除;然后不需要初始化创世块,直接执行上面的命令进入控制台就可以了,如下所示:
[root@localhost rungeth]# rm -rf data #删除data目录(解决根源)
[root@localhost rungeth]# ls
1.log genesis.json rungeth.sh
[root@localhost rungeth]# rm -rf 1.log #删除日志文件
[root@localhost rungeth]# ls
genesis.json rungeth.sh
[root@localhost rungeth]# geth --datadir ./data --networkid 108 --port 30303 --http --http.addr 0.0.0.0 --http.vhosts "*" --http.api "db,net.eth.web3,personal" --http.corsdomain "*" --snapshot=false --allow-insecure-unlock --dev --dev.period 1 console 2>1.log #重新执行开发者模式开启GETH,成功啦!!!
Welcome to the Geth JavaScript console!
instance: Geth/v1.10.16-stable-20356e57/linux-amd64/go1.17.5
coinbase: 0x1ed50f40f3ee7b921d6d3734f6b7bbb5f655974b
at block: 1 (Mon Apr 04 2022 18:48:18 GMT+0800 (CST))
datadir: /usr/local/geth-alltools-1.10.16/rungeth/data
modules: admin:1.0 clique:1.0 debug:1.0 eth:1.0 miner:1.0 net:1.0 personal:1.0 rpc:1.0 txpool:1.0 web3:1.0
To exit, press ctrl-d or type exit
> eth.accounts #查看账户,发现已经创建一个账户了
["0x1ed50f40f3ee7b921d6d3734f6b7bbb5f655974b"]
>