如何使用相同的ip创建Tendermint本地网络

时间:2018-04-11 13:16:26

标签: tendermint

如何在建立具有相同IP地址的本地Tendermint网络时设置config.toml文件。我是否需要同时设置种子'和' persistent_peers'对于每个节点?

节点1

congfig.toml

proxy_app = "tcp://127.0.0.1:46658"
moniker = "pc-4e76-2"
fast_sync = false
db_backend = "leveldb"
db_path = "data"
log_level = "main:info,state:info,*:error"
genesis_file = "config/genesis.json"
priv_validator_file = "config/priv_validator.json"
node_key_file = "config/node_key.json"
abci = "socket"
prof_laddr = ""
filter_peers = false

[rpc]
laddr = "tcp://0.0.0.0:46657"
grpc_laddr = ""
unsafe = false

[p2p]
laddr = "tcp://0.0.0.0:46656"
seeds = ""
persistent_peers = "tcp://0.0.0.0:46659"
addr_book_file = "config/addrbook.json"
addr_book_strict = false
flush_throttle_timeout = 100
max_num_peers = 50
max_msg_packet_payload_size = 1024
send_rate = 512000
recv_rate = 512000
pex = true
seed_mode = false

[mempool]
recheck = true
recheck_empty = true
broadcast = true
wal_dir = "data/mempool.wal"

[consensus]
wal_file = "data/cs.wal/wal"
wal_light = false
timeout_propose = 3000
timeout_propose_delta = 500
timeout_prevote = 1000
timeout_prevote_delta = 500
timeout_precommit = 1000
timeout_precommit_delta = 500
timeout_commit = 1000
skip_timeout_commit = false
max_block_size_txs = 10000
max_block_size_bytes = 1
create_empty_blocks = false
create_empty_blocks_interval = 0
peer_gossip_sleep_duration = 100
peer_query_maj23_sleep_duration = 2000

[tx_index]
indexer = "kv"
index_tags = ""
index_all_tags = false

gensis.json

{
    "genesis_time": "0001-01-01T00:00:00Z",
    "chain_id": "test-chain-1uFNom",
    "validators": [
        {
            "pub_key": {
                "type": "ed25519",
                "data": "2920010B3C75FF9A33E6DF2BB483FE936CCD40A84B929FEABC86EA1B167FD613"
            },
            "power": 10,
            "name": ""
        },
        {
            "pub_key": {
                "type": "ed25519",
                "data": "1B6D7C4898007A7BB48E36FC11B8F5296A4FBF8B1280DD5A950F45A9064C8937"
            },
            "power": 10,
            "name": ""
        }

    ],
    "app_hash": ""
}

priv_validator.json

{
    "address": "C63DF7A33A2D72B908349CF99106B003BEEA8DF2",
    "pub_key": {
        "type": "ed25519",
        "data": 
"2920010B3C75FF9A33E6DF2BB483FE936CCD40A84B929FEABC86EA1B167FD613"
    },
    "last_height": 0,
    "last_round": 0,
    "last_step": 0,
    "last_signature": null,
    "priv_key": {
        "type": "ed25519",
        "data": "BA2044F3F67A24776048B938113F588C17DDCB292955DE9520BA60A0BB9FFA912920010B3C75FF9A33E6DF2BB483FE936CCD40A84B929FEABC86EA1B167FD613"
    }
}

节点2

config.toml

[rpc]
laddr = "tcp://0.0.0.0:46660"
[p2p]
laddr = "tcp://0.0.0.0:46659"
seeds = ""
persistent_peers = "tcp://0.0.0.0:46656"

(其他设置与node1相同)

gensis.json 与node1相同

priv_validator.json

{
    "address": "606FF21C48917E12EBC2266A3ED6168F8BE459A0",
    "pub_key": {
        "type": "ed25519",
        "data": "1B6D7C4898007A7BB48E36FC11B8F5296A4FBF8B1280DD5A950F45A9064C8937"
    },
    "last_height": 0,
    "last_round": 0,
    "last_step": 0,
    "last_signature": null,
    "priv_key": {
        "type": "ed25519",
        "data": "B05ACBB6DA6D9086827F057FEF6A03EA5F440853330B32540D6E3611F232106B1B6D7C4898007A7BB48E36FC11B8F5296A4FBF8B1280DD5A950F45A9064C8937"
    }
}
  

我尝试了很多方法。有时我可以运行节点,但无法正确提交事务。

这些是我在本地使用相同IP地址创建两个验证器节点的所有设置。我得到了错误#34;重复同行"和#34;连接到自我"。

Ensure peers                                 module=p2p numOutPeers=1 numDialing=0 numToDial=9
Will dial address                            module=p2p addr=0.0.0.0:46659
Will dial address                            module=p2p addr=e5b4313a3c7d690c673d6daf8bcbe5a69504274c@10.66.31.178:46656
We need more addresses. Sending pexRequest to random peer module=p2p peer="Peer{MConn{127.0.0.1:46659} 7fe6d6fd249279345bc57f114423d100c21151a5 out}"
Dialing peer                                 module=p2p address=0.0.0.0:46659
Dialing peer                                 module=p2p address=e5b4313a3c7d690c673d6daf8bcbe5a69504274c@10.66.31.178:46656
Failed to add peer                           module=p2p address=e5b4313a3c7d690c673d6daf8bcbe5a69504274c@10.66.31.178:46656 err="Connect to self"
Ignoring inbound connection: error while adding peer module=p2p address=10.66.31.178:51238 err="Connect to self"
Dialed peer with unknown ID - unable to authenticate module=p2p peer=0.0.0.0:46659 addr=0.0.0.0:46659
Failed to add peer                           module=p2p address=0.0.0.0:46659 err="Duplicate peer"

2 个答案:

答案 0 :(得分:0)

足以设置persistent_peers

队列(https://github.com/tendermint/tendermint/pull/1449/files)有一个改进,它将修复tendermint testnet命令,以便您可以使用它作为示例。它填充config.toml文件persistent_peers参数。

"无法提交交易"可能是因为不同的问题。例如,您的genesis.json可能有错误的设置。当前形式的testnet命令生成一个工作的genesis.json,试试看你是否发现配置有任何问题。

答案 1 :(得分:0)

  

我是否需要同时设置种子'和' persistent_peers'对于每个节点?

不,请使用persistent_peers

  

具有未知ID的被叫对等方 - 无法进行身份验证

请预先添加IP:具有相应节点ID的端口对。 https://tendermint.readthedocs.io/projects/tools/en/develop/using-tendermint.html#peers。您可以使用tendermint show_node_id获取节点ID。或者更好的是,使用tendermint testnet命令创建本地testnet。