本章节演示如何部署自己的区块链网络。
以三个节点为示例部署区块链网络。
三个网络节点:
- 节点1是区块链网络中的第一个节点,它可以生成新区块并从连接到它的客户端发送交易;
- 节点2是另一个荣誉节点,它可以生成新区块并从连接到它的客户端发送交易;
- 节点3是一个守护节点,它不能生成新区块,但可以从连接到它的客户端发送交易。
三个节点部署以下配置:
- 每个节点都使用自己的PostgreSQL数据库系统实例;
- 每个节点都使用自己的Centrifugo服务实例;
- 服务端 与其他后端组件部署在同一主机上。
节点使用的示例地址和端口如下表所述:
节点 | 组件 | IP和端口 |
1 | PostgreSQL | 127.0.0.1:5432 |
1 | Centrifugo | 192.168.1.1:8000 |
1 | go-ibax (TCP服务) | 192.168.1.1:7078 |
1 | go-ibax (API服务) | 192.168.1.1:7079 |
2 | PostgreSQL | 127.0.0.1:5432 |
2 | Centrifugo | 192.168.1.2:8000 |
2 | go-ibax (TCP服务) | 192.168.1.2:7078 |
2 | go-ibax (API服务) | 192.168.1.2:7079 |
3 | PostgreSQL | 127.0.0.1:5432 |
3 | Centrifugo | 192.168.1.3:8000 |
3 | go-ibax (TCP服务) | 192.168.1.3:7078 |
3 | go-ibax (API服务) | 192.168.1.3:7079 |
您自己的区块链网络必须分几个阶段部署:
第一个节点是一个特殊节点,因为它必须用于启动区块链网络。区块链的第一个区块由第一个节点生成,所有其他节点从中下载区块链。第一个节点的所有者为平台创始人。
Debian 9的所有命令必须以非root用户身份运行。但是某些系统命令需要执行超级用户权限。默认情况下,Debian 9上没有安装sudo,您必须先安装它。
- 成为超级用户。
su -
- 升级您的系统。
apt update -y && apt upgrade -y && apt dist-upgrade -y
- 安装sudo。
apt install sudo -y
- 将您的用户添加到sudo组。
usermod -a -G sudo user
- 重启后,更改生效。
按照 官方文档 的说明按照Go。
- 从 Golang官方网站或通过命令行下载最新的稳定版Go(> 1.10.x):
wget https://dl.google.com/go/go1.11.2.linux-amd64.tar.gz
- 将安装包解压缩到
/usr/local
.
tar -C /usr/local -xzf go1.11.2.linux-amd64.tar.gz
- 添加
/usr/local/go/bin
到PATH环境变量 (位于/etc/profile
或$HOME/.profile
)。
export PATH=$PATH:/usr/local/go/bin
- 要使更改生效,请执行
source
该文件,例如:
source $HOME/.profile
- 删除临时文件:
rm go1.11.2.linux-amd64.tar.gz
- 安装PostgreSQL(> v.10)和psql:
sudo apt install -y postgresql
- 从 GitHub或通过命令行下载Centrifugo 1.8.0版本:
wget https://github.com/centrifugal/centrifugo/releases/download/v1.8.0/centrifugo-1.8.0-linux-amd64.zip \
&& unzip centrifugo-1.8.0-linux-amd64.zip \
&& mkdir centrifugo \
&& mv centrifugo-1.8.0-linux-amd64/* centrifugo/
- 删除临时文件:
rm -R centrifugo-1.8.0-linux-amd64 \
&& rm centrifugo-1.8.0-linux-amd64.zip
对于Debian 9 系统,建议将区块链平台使用的所有软件存储在单独的目录中。
在这里使用 /opt/backenddir
目录,但您可以使用任何目录。在这种情况下,请相应地更改所有命令和配置文件。
- 为区块链平台创建一个目录:
sudo mkdir /opt/backenddir
- 使您的用户成为该目录的所有者:
sudo chown user /opt/backenddir/
- 为Centrifugo、go-ibax 和节点数据创建子目录。所有节点数据都存储在名为
nodeX
的目录中,其中X
为节点号。根据要部署的节点,node1
为节点1,node2
为节点2,以此类推。
mkdir /opt/backenddir/go-ibax \
mkdir /opt/backenddir/go-ibax/node1 \
mkdir /opt/backenddir/centrifugo \
- 将用户密码postgres更改为默认密码123456。您可以设置自己的密码,但必须在节点配置文件 config.toml中进行更改。
sudo -u postgres psql -c "ALTER USER postgres WITH PASSWORD '123456'"
- 创建节点当前状态数据库,例如 chaindb:
sudo -u postgres psql -c "CREATE DATABASE chaindb"
- 创建Centrifugo配置文件:
echo '{"secret":"CENT_SECRET"}' > /opt/backenddir/centrifugo/config.json
您可以设置自己的 secret,但是您还必须在节点配置文件 config.toml 中更改它。
- 从GitHub下载 https://github.com/ibax-io/go-ibax:
- 将 go-ibax 二进制文件复制到
/opt/backenddir/go-ibax
目录。如果您使用的是默认的Go工作区 则二进制文件位于$HOME/go/bin
目录:
cp $HOME/go/bin/go-ibax /opt/backenddir/go-ibax
- 创建节点1配置文件:
/opt/backenddir/go-ibax config \
--dataDir=/opt/backenddir/node1 \
--dbName=chaindb \
--centSecret="CENT_SECRET" --centUrl=http://192.168.1.1:8000 \
--httpHost=192.168.1.1 \
--httpPort=7079 \
--tcpHost=192.168.1.1 \
--tcpPort=7078
- 生成节点1的密钥,包括节点公私钥和账户公私钥:
/opt/backenddir/go-ibax generateKeys \
--config=/opt/backenddir/node1/config.toml
- 生成第一个区块:
如果您要创建自己的区块链网络。你必须使用该 `--test=true` 选项。否则您将无法创建新帐户。
/opt/backenddir/go-ibax generateFirstBlock \
--config=/opt/backenddir/node1/config.toml \
--test=true
- 初始化数据库:
/opt/backenddir/go-ibax initDatabase \
--config=/opt/backenddir/node1/config.toml
要启动第一个节点服务端,您必须启动两个服务:
- centrifugo
- go-ibax
如果您没有将这些文件创建services ,那么您可以从不同控制台的目录中执行二进制文件。
- 运行centrifugo:
/opt/backenddir/centrifugo/centrifugo \
-a 192.168.1.1 -p 8000 \
--config /opt/backenddir/centrifugo/config.json
- 运行 go-ibax:
/opt/backenddir/go-ibax start \
--config=/opt/backenddir/node1/config.toml
所有其他节点(节点2和节点3)的部署与第一个节点类似,但有三个不同之处:
- 您不需要生成第一个区块。但是它必须从节点1复制到当前节点数据目录;
- 该节点必须通过配置
--nodesAddr
选项从节点1下载区块; - 该节点必须使用自己的地址和端口。
按照以下一系列操作:
创建节点2配置文件:
/opt/backenddir/go-ibax config \ --dataDir=/opt/backenddir/node2 \ --dbName=chaindb \ --centSecret="CENT_SECRET" --centUrl=http://192.168.1.2:8000 \ --httpHost=192.168.1.2 \ --httpPort=7079 \ --tcpHost=192.168.1.2 \ --tcpPort=7078 \ --nodesAddr=192.168.1.1
复制第一个区块文件到节点2,例如,您可以通过
scp
在节点2执行该操作:scp [email protected]:/opt/backenddir/node1/1block /opt/backenddir/node2/生成节点2的密钥,包括节点公私钥和账户公私钥:
/opt/backenddir/go-ibax generateKeys \ --config=/opt/backenddir/node2/config.toml初始化数据库:
./go-ibax initDatabase --config=node2/config.toml运行centrifugo:
/opt/backenddir/centrifugo/centrifugo \ -a 192.168.1.2 -p 8000 \ --config/opt/backenddir/centrifugo/config.json运行 go-ibax:
/opt/backenddir/go-ibax start \ --config=/opt/backenddir/node2/config.toml
结果,节点从第一个节点下载区块。该节点不是验证节点,因此无法生成新区块。节点2将后面添加到验证节点列表中。
按照以下一系列操作:
-
创建节点3配置文件:
/opt/backenddir/go-ibax config \ --dataDir=/opt/backenddir/node3 \ --dbName=chaindb \ --centSecret="CENT_SECRET" --centUrl=http://192.168.1.3:8000 \ --httpHost=192.168.1.3 \ --httpPort=7079 \ --tcpHost=192.168.1.3 \ --tcpPort=7078 \ --nodesAddr=192.168.1.1
-
复制第一个区块文件到节点3,例如,您可以通过
scp
在节点3执行该操作:scp [email protected]:/opt/backenddir/node1/1block /opt/backenddir/node3/
-
生成节点3的密钥,包括节点公私钥和账户公私钥:
/opt/backenddir/go-ibax generateKeys \ --config=/opt/backenddir/node3/config.toml
-
初始化数据库:
./go-ibax initDatabase --config=node3/config.toml
-
运行centrifugo:
/opt/backenddir/centrifugo/centrifugo \ -a 192.168.1.3 -p 8000 \ --config/opt/backenddir/centrifugo/config.json
-
运行 go-ibax:
/opt/backenddir/go-ibax start \ --config=/opt/backenddir/node3/config.toml
结果,节点从第一个节点下载区块。该节点不是验证节点,因此无法生成新区块。客户端可以连接到该节点,它可以将交易发送到网络。
只有在Debian 9(Stretch)64位官方发行版 上安装 GNOMEGUI,Govis客户端才能由 yarn
包管理器构建。
Node.js
- 从 Node.js官方网站或通过命令行下载Node.js LTS版本8.11 :
curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash
- 安装Node.js:
sudo apt install -y nodejs
Yarn
- 从 yarn的Github仓库或通过命令行下载Yarn版本1.7.0 :
cd/opt/backenddir \
&& wget https://github.com/yarnpkg/yarn/releases/download/v1.7.0/yarn_1.7.0_all.deb
- 安装Yarn:
sudo dpkg -i yarn_1.7.0_all.deb && rm yarn_1.7.0_all.deb
- 通过git从 https://github.com/ibax-io/ibax-front 下载 Weaver 的最新版本:
cd/opt/backenddir \
&& git clone https://github.com/ibax-io/ibax-front.git
- 通过Yarn安装 Weaver 依赖项:
cd/opt/backenddir/ibax-front/ \
&& yarn install
- 创建包含有关节点连接信息的 settings.json 文件:
cp/opt/backenddir/ibax-front/public/settings.json.dist \
/opt/backenddir/ibax-front/public/public/settings.json
- 在任何文本编辑器中编辑 settings.json 文件,并以此格式添加所需的设置:
http://Node_IP-address:Node_HTTP-Port
三个节点的 settings.json 文件示例:
{
"fullNodes": [
"http://192.168.1.1:7079",
"http://192.168.1.2:7079",
"http://192.168.1.3:7079"
]
}
构建 Weaver 桌面版应用程序
- 使用yarn构建桌面版:
cd/opt/backenddir/ibax-front \
&& yarn build-desktop
- 桌面版将打包成AppImage后缀格式:
yarn release --publish never -l
构建之后,您的应用程序就可以使用了,但是其连接配置 将无法更改。如果这些设置需要更改,则必须构建新版本的应用程序。
- 构建Web应用程序:
cd/opt/backenddir/ibax-front/ \
&& yarn build
构建之后,可再发行文件将放置到 build目录中。您可以使用您选择的任何Web服务器进行部署,settings.json文件也必须放在该目录。请注意,如果连接设置发生更改,则无需再次构建应用程序。而是编辑settings.json 文件并重新启动Web服务器。
- 出于开发或测试目的,您可以构建Yarn的Web服务器:
sudo yarn global add serve \
&& serve -s build
之后,您的 Weaver Web应用程序将在以下位置可用: http://localhost:5000
。
为第一个节点所有者创建一个帐户。该帐户是新区块链平台的创始人,并具有管理员访问权限。
-
运行 Weaver;
-
使用以下数据导入现有帐户:
- 节点所有者私钥的备份加载位于
/opt/backenddir/node1/PrivateKey
文件中。
该目录中有两个私钥文件: `PrivateKey` 文件用于节点所有者的帐户,可创建节点所有者的帐户。 `NodePrivateKey` 文件是节点本身的私钥,必须保密。
- 节点所有者私钥的备份加载位于
-
登录该账户后,由于此时尚未创建角色,因此请选择 Without role 选项。
此时,区块链平台处于空白状态。您可以通过添加支持基本生态系统功能的角色、模版和应用程序框架来配置它。
- 克隆应用程序存储库;
cd/opt/backenddir \
&& git clone https://github.com/ibax-io/dapps.git
-
在 Weaver 中导航到 Developer > 导入;
-
按此顺序导入应用:
A./opt/backenddir/dapps/system.json B./opt/backenddir/dapps/conditions.json C./opt/backenddir/dapps/basic.json D./opt/backenddir/dapps/lang_res.json
-
导航到 Developer > 角色,然后单击 安装默认角色;
-
通过右上角的配置文件菜单退出系统;
-
以 Developer 角色登录系统;
-
导航到 Home > 投票 > 模版列表,然后单击 安装默认模版。
-
导航到 Developer > 平台参数,然后单击 first_nodes 参数;
-
指定第一个区块链网络节点的参数。
- public_key - 节点公钥位于
/opt/backenddir/node1/NodePublicKey
文件;
{"api_address":"http://192.168.1.1:7079","public_key":"%node_public_key%","tcp_address":"192.168.1.1:7078"}
- public_key - 节点公钥位于
默认情况下,只有共识角色(Consensus)的成员才能参与添加其他 荣誉节点所需的投票。这意味着在添加新的 荣誉节点之前,必须为该角色指定生态系统的成员。
在本章节中,创始人的帐户被指定为共识角色的唯一成员。在生产环境中,必须将该角色分配给平台执行治理的成员。
- 导航到 Home > 角色 ,然后单击共识角色(Consensus);
- 单击 分配 将创始人的帐户分配给该角色。
-
运行 Weaver;
-
使用以下数据导入现有帐户:
- 节点所有者私钥的备份加载位于
/opt/backenddir/node2/PrivateKey
文件中。
- 节点所有者私钥的备份加载位于
-
登录该账户后,由于此时尚未创建角色,因此请选择 Without role 选项;
-
导航到 Home > 个人信息,然后单击个人信息名称;
-
添加帐户详细信息(个人信息名称,说明等)。
-
新节点所有者操作:
A. 导航到 Home > 验证者; B. 单击 创建请求 并填写验证者候选人的申请表; C. 单击 发送请求。
-
创始人操作:
A. 以共识角色(Consensus)登录; B. 导航到 Home > 验证者; C. 根据候选人的请求点击"播放"图标开始投票; D. 导航到 Home > 投票,然后单击 更新投票状态; E. 单击投票名称并为节点所有者投票。
结果,新节点所有者的帐户被分配给 Validator 角色,并且新节点也被添加到荣誉节点列表中。