BSC全节点搭建2023最新教程 - 超级详细教程

一、服务器配置要求

系统:Mac & Linux
CPU16核
内存:64 GB 内存
带宽:50M以上
硬盘:大于2T固态SSD可用空间数据盘
  • 本次搭建使用配置
系统:Ubuntu
CPU32核心64线程
内存:128GB 内存
带宽:1000M上下对等
硬盘:固态8T


二、系统环境准备

ubuntu一键更新:

apt-get update&&apt install wget -y&&apt install git -y&&apt install golang -y&&apt -y install screen&&apt -y install gcc automake autoconf libtool make&&apt install unzip -y&&apt install aria2 -y&&apt install vim -y
  1. 更新软件包
#Centos
yum -y upgrade
#Ubuntu
apt-get update
  1. 安装wget和git
#Centos
yum install wget -y
yum install git -y
#Ubuntu
apt install wget -y
apt install git -y
  1. 安装Golang(安装 Go 主要是为了去编译 go-ethereum 源码)
#Centos
yum install golang -y
#Ubuntu
apt install golang -y

此命令如果安装不上,请手动安装:https://www.runoob.com/go/go-environment.html

使用go version确认安装正确

go version

如下显示则安装正确。

[root@localhost ~]# go version
go version go1.18.1 linux/amd64
  1. 安装linux下的窗口管理器工具screen
#Centos
yum -y install screen
#Ubuntu
apt -y install screen

三、节点安装部署

在根目录创建jiedian文件夹用来存放节点程序,并在同时在jiedian里边创建一个kuaizhao文件夹,下载的快照数据

1.务必使用固态硬盘并且可使用空间大于2T
2.如果固态不够使用,可以把快照压缩包下载到机械硬盘里边,解压的时候解压到固态硬盘

  • 安装BSC版本的geth
cd /		#进入根目录
mkdir -p jiedian/kuaizhao		#创建jiedian及kuaizhao文件夹
cd /jiedian		#进入jiedian文件夹
git clone https://github.com/binance-chain/bsc
cd bsc/
make geth

Ubuntu如果不能make使用下列命令跑一下就好了

#Ubuntu
apt -y install gcc automake autoconf libtool make

配置路径

vim /etc/profile
#把下列一行写到最后边然后 :wq 保存退出
export PATH=$PATH:/jiedian/bsc/build/bin
#然后使命令生效
source /etc/profile

使用geth version确认安装正确

  • 配置创世块
wget   $(curl -s https://api.github.com/repos/bnb-chain/bsc/releases/latest |grep browser_ |grep mainnet |cut -d\" -f4)
unzip mainnet.zip
geth --datadir node init genesis.json
  • 下载BSC快照

创建一个用来下载快照的screen窗口

screen -S xiazai

*注意1:使用screen窗口期间可以退出或者关闭命令行对话框。
*注意2:退出当前窗口时用ctrl+ad(顺序按a和d字母即可),绝对不要用exit或ctrl+d退出会话。
*注意2:退出会话后,可以用screen -x xiazai重新连接到会话。这样可以保持在shell下运行,网络中断不会影响。

开始下载快照

cd /jiedian/kuaizhao		#进入kuaizhao文件夹下载快照
wget -O geth.tar.lz4 "最新下载地址"
cd /jiedian/kuaizhao		#进入kuaizhao文件夹下载快照
aria2c -s14 -x14 -k100M 下载地址 -o geth.tar.lz4

这里要下载很久,所以带宽要尽可能高。
在这里获取最新全节点快照地址
BSC快照github:https://github.com/BNB48Club/bsc-snapshots

下载完成后解压 并移动 chaindata 和 triecache 到./jiedian/bsc/node/geth/ 文件夹下

lz4 -cd geth.tar.lz4 | tar xf -      #在kuaizhao目录解压数据包
rm -rf /jiedian/bsc/node/geth/chaindata
mv /jiedian/kuaizhao/geth/chaindata /jiedian/bsc/node/geth
mv /jiedian/kuaizhao/geth/triecache /jiedian/bsc/node/geth

移动完毕以后退出screen的xiazai窗口,并创建bsc窗口并开始运行节点。

退出当前窗口时用ctrl+ad(顺序按a和d字母即可),绝对不要用exit或ctrl+d退出会话

ctrl+ad		#退出xiazai窗口

启动之前可以先自行配置一下节点的配置文件

  • 修改BSC主网配置文件
vim /jiedian/bsc/config.toml

参数说明:

TrieTimeout:这意味着geth将不会将状态持久化到数据库中,直到达到这个时间阈值,如果节点已经被强制关闭,它将从最后一个状态开始同步,这可能需要很长时间,可设置为:TrieTimeout
= 200000000000
注意:当TrieTimeout值设置的越大,系统崩溃后,节点恢复的时间越长

HTTPHost: HTTP-RPC服务连接白名单,此参数的值默认为 “localhost”,仅允许本地可访问,如果需要外网访问节点请设置为:“0.0.0.0”

HTTPVirtualHosts:HTTP-RPC服务监听接口,此参数的值默认为[“localhost”],可设置为:HTTPVirtualHosts = [“*”]

HTTPPort:http协议rpc端口

WSPort:websocket协议rpc端口

WSHost:websocket服务连接白名单,此参数的值默认为 “localhost”,仅允许本地可访问,可设置为:“0.0.0.0”

WSOrigins:websocket服务监听接口,可设置为:WSOrigins = [“*”]

三、启动BSC智能全节点

screen -S bsc	#创建bsc节点启动窗口
geth --config ./config.toml --datadir ./node --txlookuplimit 0 --cache 86016 --rpc.allow-unprotected-txs --syncmode full --tries-verify-mode none --diffblock 5000 --rpc.txfeecap 0 --rpc.gascap 0 --http --http.corsdomain "*" --pruneancient=true --diffsync=true

然后按ctrl+ad回到主会话即可

参数说明:

–config:指定BSC节点配置文件

–datadir:指定BSC节点数据库和密钥存储库的数据目录(默认即可)

–cache:设置最大分配给内部缓存的内存,默认:1024(设置越大,每次同步的数据越多,消耗的内存也越大)

–rpc.allow-unprotected-txs:允许通过RPC提交不受保护的(非 EIP155 签名)交易

–txlookuplimit 0 : 禁用删除事务索引

–diffsync:启用差异同步协议来帮助节点更快地同步

–rpc.txfeecap:无上限gas费用

–rpc.gascap:无交易费用上限

四、节点状态监听

geth attach http://127.0.0.1:8545
#这里的端口如果修改配置文件了,就填写配置文件的端口即可
> eth.syncing	#查看当前块情况

说明:

currentBlock: 14290861, #当前同步到块高度
highestBlock: 14297354, #主网当前高度
knownStates:297473485,
pulledStates: 297473485,
startingBlock: 14270385

> net.peerCount	#查看当前连接节点数量,结果为false为同步完成
> eth.blockNumber #当前同步到块高度

退出请按 ctrl+d 回到主会话。

  • 停止节点

打开bsc窗口

 screen -x bsc

然后按 ctrl+c 即可

引导节点将在不久的将来得到增强。到目前为止,发现 http 服务将提供一些稳定的公共 p2p 对等点进行同步。请访问https://api.binance.org/v1/discovery/peers获取动态对等信息。您可以将对等信息附加到StaticNodesconfig.toml 中以增强完整节点的网络。为了避免拥挤的网络,发现服务会不时更改节点信息,如果全节点连接的节点太少,请尝试获取新节点。

五、注意事项

1.Centos设备配置同步情况

我这台Centos的设备配置同步到最高块用了大概10小时左右就追到了最高块,在使用固态之前用机械硬盘试了一下,每秒1个块,可以说相当拉胯了,所以还是推荐直接上SSD,硬盘最好4T空间,否则块数据都要1.9个T,如果只有2T空间根本不够用。

2.Ubuntu设备配置同步情况

这台就快多了,下载快照:2.5-3个小时,解压:30-40分钟,同步到最新块:2.5个小时,主要是这台硬盘是全固态,内存也大,带宽也大,1G上下对等。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

在穷不能穷教育

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值