Cypherium's synchronous block test operation steps

转载请标注原文地址:https://lilyssh.cn/blockchain/cypherium-test-sync-block-en/

前言

Cypherium’s synchronous block test operation steps.

  1. put cypherium_internal.pem in a directory,for example,~.

  2. vim ~/.ssh/config file.Add alias for the ssh remote connection.

1
2
3
4
5
6
7
8
9
10
Host *
ServerAliveInterval 60
Host 119
HostName 18.221.58.119
User ubuntu
IdentityFile ~/cypherium_internal.pem
Host 200
HostName 18.216.16.200
User ubuntu
IdentityFile ~/cypherium_internal.pem
  1. ssh 119,connection AWS node 18.221.58.119.
1
2
3
4
5
6
7
8
9
10
ubuntu@ip-172-31-31-48:~$
$ tree
.
├── genesis.json
├── group.toml
├── Cypherium
│   ├── private.toml
│ └── public.toml
└── cypher_db
├── cypher.ipc
  1. clean
1
make clean
  1. Compile
1
make cypher
  1. Generate node information
1
./build/bin/cypher setup

You need to enter the ip: port,Use kyber’s Ed25519 algorithm to generate public.toml and private.toml.Save in the default path. Currently there is no ip discovery, so you need to manually splicing the public key ~/Library/Application\ Support/cypher/public.toml (Mac default path) for simulation testing. The node name can be customized, such as node_01_name.

  1. 同理,再生成第二个节点。

  2. 把第一、二个节点的public.toml,拼接到~/workspace/test/group.toml中。

  1. 初始化 两个节点的创世区块。

第一个节点:

1
./build/bin/cypher --datadir "~/workspace/test/node_01/data" init ~/workspace/test/genesis.json

第二个节点:

1
./build/bin/cypher --datadir "~/workspace/test/node_02/data" init ~/workspace/test/genesis.json

genesis.json中内容可参考:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
{
"config": {
"chainId": 123666,
"homesteadBlock": 0,
"eip155Block": 0,
"eip158Block": 0
},
"alloc" : {},
"coinbase" : "0x0000000000000000000000000000000000000000",
"difficulty" : "0x20000",
"extraData" : "",
"gasLimit" : "0x2fefd8",
"nonce" : "0x0000000000000042",
"mixhash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
"parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
"timestamp" : "0x00"
}

  1. 启动第一个节点。
1
./build/bin/cypher --onetdir ~/workspace/test/node_01/private.toml --datadir ~/workspace/test/node_01/data --publickeydir ~/workspace/test/group.toml --networkid 123666 --port 7010 --rpcport 8510 --rpc --rpccorsdomain "*" --rpcaddr 0.0.0.0 --rpcapi eth,web3,personal --verbosity 5 2> ~/workspace/test/node_01/output2.log
  1. 启动第一个节点的js交互窗口(用上一步成的ipc文件):
1
./build/bin/cypher attach ~/workspace/test/node_01/data/cypher.ipc
  1. 启动第二个节点。
1
./build/bin/cypher --onetdir ~/workspace/test/node_02/private.toml --datadir ~/workspace/test/node_02/data --publickeydir ~/workspace/test/group.toml --networkid 123666 --port 7020 --rpcport 8520 --rpc --rpccorsdomain "*" --rpcaddr 0.0.0.0 --rpcapi eth,web3,personal --verbosity 5 2> ~/workspace/test/node_02/output2.log
  1. 启动第二个节点的js交互窗口(用上一步成的ipc文件)。
1
./build/bin/cypher attach ~/workspace/test/node_02/data/cypher.ipc

  1. 从此步骤开始,都将在js交互涌窗口执行。查看第一个节点的信息。
1
admin.nodeInfo
  1. 在第二个节点中,创建用户,保存挖矿奖励。
1
personal.newAccount("password")
  1. 在第二个节点中,加入第一个节点。就是把cnode中的内容粘进addPeer中。
1
admin.addPeer("cnode")
  1. 在第一个节点中,验证一下是否已加入。
1
net
  1. 主节点调用开始同步命令,从交易池里取tx执行,并打包生成txBlock,发给其他委员会成员做bftcosi共识。会看到两个节点的信息都在滚动。
1
bftcosi.start()
  1. 停止共识。
1
bftcosi.stop()
  1. 查看下两个节点的区块数量是否相同。

  1. (不时需要)解锁账户
1
personal.unlockAccount("需解锁账户")

  1. 查看交易池状态,pending为待确认的交易数量。
    1
    txpool.status

会显示

1
2
3
4
{
pending: 0,
queued: 0
}

  1. 退出:

本文由 lilyssh创作。可自由转载、引用,但需署名作者且注明文章出处。


当前网速较慢或者你使用的浏览器不支持博客特定功能,请尝试刷新或换用Chrome、Firefox等现代浏览器