Tron节点搭建

波场文档

支持的操作系统:LinuxMacOS

依赖和工具:Oracle JDK 1.8 ,git

推荐配置

  • CPU:16核
  • 内存:32G
  • SSD:1.5T以上
  • 带宽:100M

如果是超级代表搭建产块的全节点,建议配置是 CPU:32核, 内存:64G

1、波场节点介绍

  • 波场网络的节点主要分为两类:超级节点,全节点
①、超级节点
  • 包含全网全部区块数据,并负责共识出块
②、全节点
  • 包含全网全部区块数据

2、编译源码

  1. 获取java-tron源码
    $ git clone https://github.com/tronprotocol/java-tron.git
    $ git checkout -t origin/master
  1. 编译
    $ cd java-tron
    $ ./gradlew clean build -x test
image.png

编译完成之后,FullNode.jar会生成在 java-tron/build/libs/FullNode.jar

3、运行节点

a.) 节点需要的jar及配置文件
获取主网全节点配置文件:main_net_config.conf,其它网络节点配置文件在这里

1.FullNode.jar(项目路径/java-tron/build/libs/FullNode.jar)
2.main_net_config.conf(/项目路径/java-tron/build/libs/main_net_config.conf)   //习惯性放在同级目录

b.) 运行超级节点

目标:创建超级节点,并开始创建区块
创建节点目录superNode并拷贝相关FullNode.jar包及配置文件(见a项)

# mkdir -p /项目路径/superNode
# cp /项目路径/java-tron/build/libs/FullNode.jar /项目路径/superNode
# cp /项目路径/java-tron/build/libs/main_net_config.conf /项目路径/superNode

创建你的tron账号
可通过https://tronscan.org/ 去创建你的个人账号,并保存创建的私钥及地址信息

修改配置文件

  • 配置文件:/项目路径/superNode/main_net_config.conf* 修改genesis.block.witnesses为你个人的tron地址
    witnesses = [
    {
    address: 27PsvT28qhmUM1GHMVVJeyRskhB2pfzA1En,
    url= "http://tron.com",
    voteCount = 10000
    }
    ]* 修改seed.node.ip.list 为服务器的IP:PORT
    seed.node = {
    ip.list = [
    "123.207.xx.xxx:18888"
    ]
    }* 第一个超级节点,则需要修改needSyncCheck =false
    block = {
    needSyncCheck = false# first node : false, other : true
    maintenanceTimeInterval = 21600000 // 1 day: 86400000(ms), 6 hours: 21600000(ms)
    }* 可修改p2pversion 为你自己定制的版本,建议不修改该值

启动超级节点

cd /项目路径/superNode
java -jar FullNode.jar -p 个人地址的私钥 --witness -c /项目路径/superNode/main_net_config.conf

验证节点启动状态:

节点启动后,FullNode.jar的同级目录上将生成 logs 和 output-directory 两个文件夹
logs : 节点日志文件
output-directory : 节点数据存储目录
查看日志,确定节点是否正常启动,并在出块

超级节点启动,并创建创世块:

15:49:34.973 INFO  [main] [o.t.c.d.Manager](Manager.java:305) create genesis block
15:49:34.975 INFO  [main] [o.t.c.d.Manager](Manager.java:311) save block: BlockCapsule
[ hash=0000000000000000318b90bda4950d183bab0031b9005d4c0be1b180c21d6fde
number=0
parentId=0000000000000000000000000000000000000000000000000000000000000000
witness address=
generated by myself=true
generate time=1970-01-01 08:00:00.0
merkle root=c5b031aa2d4a77d237f785fcc760e17839a75f414b62765fcd0d614aff96ce09
txs size=4
]

超级节点正常出块:

15:55:06.008 INFO  [Thread-5] [o.t.c.d.Manager](Manager.java:1108) update solid block, num = 109
15:55:06.008 INFO  [Thread-5] [o.t.c.d.DynamicPropertiesStore](DynamicPropertiesStore.java:719) update state flag = 0
15:55:06.008 INFO  [Thread-5] [o.t.c.d.Manager](Manager.java:742) save block: BlockCapsule
[ hash=000000000000006d9b18d04237b60abb321264d2282d7a864083c32d0e3ddad9
number=109
parentId=000000000000006c7717e85f0d2db9fc089bccd9d5dc1c233a3a3bad5d557fb9
witness address=a008c7176410573e7a16bc62e5089bf25b49548ba4
generated by myself=true
generate time=2018-05-31 15:55:06.0
txs are empty
]
15:55:06.008 INFO  [Thread-5] [o.t.c.s.WitnessService](WitnessService.java:241) Produce block successfully, blockNumber:109, abSlot[509251102], blockId:000000000000006d9b18d04237b60abb321264d2282d7a864083c32d0e3ddad9, transactionSize:0, blockTime:2018-05-31T15:55:06.000+08:00, parentBlockId:000000000000006d9b18d04237b60abb321264d2282d7a864083c32d0e3ddad9
15:55:06.008 INFO  [Thread-5] [o.t.c.n.n.NodeImpl](NodeImpl.java:347) Ready to broadcast block 000000000000006d9b18d04237b60abb321264d2282d7a864083c32d0e3ddad9

c.) 运行Full Node

目标:创建全节点,并连上自建的超级节点同步数据
准备全节点的jar包及配置文件:

在全节点服务器上创建节点目录:mkdir -p /项目路径/fullNode
拷贝步骤b)的jar包及配置文件到全节点服务器/项目路径//fullNode目录下

修改配置文件:

将超级节点加入active列表
active = [
"123.207.xx.xxx:18888"
]
修改needSyncCheck =true
block = {
needSyncCheck = true# first node : false, other : true
maintenanceTimeInterval = 21600000 // 1 day: 86400000(ms), 6 hours: 21600000(ms)
}

启动全节点:

cd /项目路径/fullNode
java -jar FullNode.jar -c /项目路径/fullNode/main_net_config.conf

验证全节点:

节点启动后,FullNode.jar的同级目录上将生成 logs 和 output-directory 两个文件夹
logs : 节点日志文件
output-directory : 节点数据存储目录
查看日志,确定节点是否正常启动,并在同步区块

全节点启动,并创建创世块:

16:19:15.399 INFO  [main] [o.t.c.d.Manager](Manager.java:305) create genesis block
16:19:15.401 INFO  [main] [o.t.c.d.Manager](Manager.java:311) save block: BlockCapsule
[ hash=0000000000000000318b90bda4950d183bab0031b9005d4c0be1b180c21d6fde
number=0
parentId=0000000000000000000000000000000000000000000000000000000000000000
witness address=
generated by myself=true
generate time=1970-01-01 08:00:00.0
merkle root=c5b031aa2d4a77d237f785fcc760e17839a75f414b62765fcd0d614aff96ce09
txs size=4
]
16:19:15.401 INFO  [main] [o.t.c.d.DynamicPropertiesStore](DynamicPropertiesStore.java:706) update latest block header number = 0
16:19:15.401 INFO  [main] [o.t.c.d.DynamicPropertiesStore](DynamicPropertiesStore.java:714) update latest block header id = 0000000000000000318b90bda4950d183bab0031b9005d4c0be1b180c21d6fde

连接超级节点:

16:24:52.645 INFO  [TronJClientWorker-0] [HandshakeHandler](HandshakeHandler.java:73) channel active, /123.207.xx.xxx:18888
16:24:52.652 INFO  [TronJClientWorker-0] [HandshakeHandler](HandshakeHandler.java:122) Handshake Send to /123.207.xx.xxx:18888, type: P2P_HELLO
from {
  address: "47.74.xx.xxx"
  port: 18888
  nodeId: "\344\276\257|\232\261f\370r\367\231\203\034\t\212\336\212\034\350\260\020X\324\025\233:\223\'6\311-AD\002\203\236O\034\250\367\300,\313\211\236\210\263\352\327\026\335|\223\030\356\200\356\320D\030"
}

从超级节点同步区块

16:24:53.872 INFO  [TronJClientWorker-0] [MessageQueue](MessageQueue.java:104) Receive from /123.207.xx.xxx:18888, type: BLOCK
Num:1,ID:000000000000000111033c4e558ef57e3063a949856528c368aa126c1f4e6cef, trx size: 0

16:24:53.874 INFO  [TronJClientWorker-0] [MessageQueue](MessageQueue.java:104) Receive from /123.207.xx.xxx:18888, type: BLOCK
Num:2,ID:0000000000000002f385a7ade9ef2afd9139cf4a491ddd0a4a001ce20eccf3c4, trx size: 0

16:24:53.874 INFO  [TronJClientWorker-0] [MessageQueue](MessageQueue.java:104) Receive from /123.207.xx.xxx:18888, type: BLOCK
Num:3,ID:0000000000000003bcbd41f1ee2e64dad8e61b40342561f3a3184930d8dc4959, trx size: 0

16:24:53.875 INFO  [TronJClientWorker-0] [MessageQueue](MessageQueue.java:104) Receive from /123.207.xx.xxx:18888, type: BLOCK
Num:4,ID:00000000000000046923e5cf0f999c3935d80bdeb8b4fa55b1aec58ed056a4fb, trx size: 0
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,529评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,015评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,409评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,385评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,387评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,466评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,880评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,528评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,727评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,528评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,602评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,302评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,873评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,890评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,132评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,777评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,310评论 2 342

推荐阅读更多精彩内容