本文根据 Fisco-BCOS 及 Webase 官方文档,就安装过程做了详细描述。针对官方文档中一些不清楚的地方,做了补充,方便新手搭建。
Ubuntu 20.04.3 Desktop / Server
Fisco-BCOS 2.8.0
硬件推荐配置 | 实际配置 | |
---|---|---|
CPU | 2.4GHz * 8核 | 8核 |
内存 | 8GB | 12GB |
存储 | 4TB | 128GB |
网络带宽 | 10Mbps | 1000Mbps |
sudo apt update -y && sudo apt upgrade -y
注意:对于 Ubuntu Server 20.04,由于系统默认已经安装并配置了 openSSH,故无需此步骤。
而 Ubuntu Desktop 20.04 则未配置 SSH,需手动配置。配置命令如下:
sudo apt install openssh-server -y sudo ufw allow ssh
此处将所有需要用到的依赖包,一并安装。
sudo apt install -y openssl curl wget git nginx dos2unix vim python3-pip unzip software-properties-common dirmngr apt-transport-https
由于 Ubuntu 20.04 自带 Python 3.8 版,符合 Fisco-BCOS 安装要求,因此不必再重复安装。
安装 PyMySQL 库
sudo pip3 install PyMySQL
创建新的文件夹,安装 Java 8 或以上的版本,推荐 JDK 8 - JDK 13 版本,将下载的 jdk 放在 /usr/local 目录
从Oracle官网( https://www.oracle.com/java/technologies/downloads/#java8 )选择Java 8或以上的版本下载,例如下载 jdk-8u311-linux-x64.tar.gz
# 移动 JDK 包到 /usr/local 目录 cp ./jdk-8u311-linux-x64.tar.gz /usr/local/ # 解压jdk sudo tar -zxvf jdk-8u311-linux-x64.tar.gz #修改解压后文件的文件名 mv jdk1.8.0_311 jdk-8u311 # 配置Java环境,编辑/etc/profile文件 sudo vim /etc/profile # 打开以后将下面三句输入到文件里面并保存退出 export JAVA_HOME=/usr/local/jdk-8u311 #这是一个文件目录,非文件 export PATH=$JAVA_HOME/bin:$PATH export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar # 生效profile # 注意,下面这条命令前,不用加 sudo source /etc/profile # 查询Java版本,出现的版本是自己下载的版本,则安装成功。 java -version javac -version
配置安装源并安装 MariaDB 10.3
sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc' sudo add-apt-repository 'deb [arch=amd64] https://mirrors.aliyun.com/mariadb/repo/10.3/ubuntu focal main' sudo apt update -y sudo apt install -y mariadb-server mariadb-client sudo systemctl enable mariadb.service
如果出现 mariadb_release_signing_key.asc 无法下载的情况,可先用 wget 下载 mariadb_release_signing_key.asc,再导入 repo 中。具体命令如下:
wget https://mariadb.org/mariadb_release_signing_key.asc sudo apt-key add mariadb_release_signing_key.asc sudo add-apt-repository 'deb [arch=amd64] https://mirrors.aliyun.com/mariadb/repo/10.3/ubuntu focal main' sudo apt update -y sudo apt install -y mariadb-server mariadb-client sudo systemctl enable mariadb.service
安装过程中,会配置 root 账户密码
用 root 账户 登录 MySQL
mysql -u root -p -h localhost -P 3306
授权root用户远程访问 与 创建test用户并授权本地访问
mysql > GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION; mysql > GRANT ALL PRIVILEGES ON *.* TO 'test'@localhost IDENTIFIED BY '123456' WITH GRANT OPTION; mysql > flush PRIVILEGES; mysql > create database webasenodemanager; mysql > exit
cd ~ && mkdir -p fisco && cd fisco
curl -#LO https://github.com/FISCO-BCOS/FISCO-BCOS/releases/download/v2.8.0/build_chain.sh && chmod u+x build_chain.sh
如果因为网络问题导致长时间无法下载 build_chain.sh 脚本,请尝试
curl -#LO https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/FISCO-BCOS/FISCO-BCOS/releases/v2.8.0/build_chain.sh && chmod u+x build_chain.sh
bash ~/fisco/build_chain.sh -l 127.0.0.1:4 -p 30300,20200,8545 ## 启动所有节点 bash ~/fisco/nodes/127.0.0.1/start_all.sh ## *关闭所有节点 bash ~/fisco/nodes/127.0.0.1/stop_all.sh
检查进程是否启动
ps -ef | grep -v grep | grep fisco-bcos
检查日志输出
tail -f ~/fisco/nodes/127.0.0.1/node0/log/log* | grep connected
检查是否在共识
tail -f ~/fisco/nodes/127.0.0.1/node0/log/log* | grep +++
获取控制台并回到fisco目录
cd ~/fisco && curl -#LO https://gitee.com/FISCO-BCOS/console/raw/master-2.0/tools/download_console.sh && bash download_console.sh && bash download_console.sh
拷贝配置文件与证书
cp -n ~/fisco/console/conf/config-example.toml ~/fisco/console/conf/config.toml cp -r ~/fisco/nodes/127.0.0.1/sdk/* ~/fisco/console/conf/、
注意:此处必须启动区块链后,才能启动控制台,否则会报错
bash ~/fisco/console/start.sh
cd ~/fisco/ && wget https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/releases/download/v1.5.3/webase-deploy.zip
这里注意,解压等操作,应使用普通账户,不能 sudo
unzip webase-deploy.zip
修改 common.properties
vi ~/webase-deploy/common.properties # ----------common.properties内容如下: # WeBASE子系统的最新版本(v1.1.0或以上版本) webase.web.version=v1.5.3 webase.mgr.version=v1.5.3 webase.sign.version=v1.5.3 webase.front.version=v1.5.3 ##################################################################### ## 使用Docker启用Mysql服务,则需要配置以下值 # 1: enable mysql in docker # 0: mysql run in host, required fill in the configuration of webase-node-mgr and webase-sign docker.mysql=1 # if [docker.mysql=1], mysql run in host (only works in [installDockerAll]) # run mysql 5.6 by docker docker.mysql.port=23306 # default user [root] docker.mysql.password=123456 ##################################################################### ## 不使用Docker启动Mysql,则需要配置以下值 # 节点管理子系统mysql数据库配置 mysql.ip=127.0.0.1 mysql.port=3306 mysql.user=dbUsername <-------这里要改 mysql.password=dbPassword <-------这里要改 mysql.database=webasenodemanager # 签名服务子系统mysql数据库配置 sign.mysql.ip=localhost sign.mysql.port=3306 sign.mysql.user=dbUsername <-------这里要改 sign.mysql.password=dbPassword <-------这里要改 sign.mysql.database=webasesign # 节点前置子系统h2数据库名和所属机构 front.h2.name=webasefront front.org=fisco # WeBASE管理平台服务端口 web.port=5000 # 启用移动端管理平台 (0: disable, 1: enable) web.h5.enable=1 # 节点管理子系统服务端口 mgr.port=5001 # 节点前置子系统端口 front.port=5002 # 签名服务子系统端口 sign.port=5004 # 节点监听Ip node.listenIp=127.0.0.1 # 节点p2p端口 node.p2pPort=30300 # 节点链上链下端口 node.channelPort=20200 # 节点rpc端口 node.rpcPort=8545 # 加密类型 (0: ECDSA算法, 1: 国密算法) encrypt.type=0 # SSL连接加密类型 (0: ECDSA SSL, 1: 国密SSL) # 只有国密链才能使用国密SSL encrypt.sslType=0 # 是否使用已有的链(yes/no) if.exist.fisco=no <-------这里要改 # 使用已有链时需配置 # 已有链的路径,start_all.sh脚本所在路径 # 路径下要存在sdk目录(sdk目录中包含了SSL所需的证书,即ca.crt、sdk.crt、sdk.key和gm目录(包含国密SSL证书,gmca.crt、gmsdk.crt、gmsdk.key、gmensdk.crt和gmensdk.key) fisco.dir=/data/app/nodes/127.0.0.1 <-------这里要改 # 前置所连接节点,在127.0.0.1目录中的节点中的一个 # 节点路径下要存在conf文件夹,conf里存放节点证书(ca.crt、node.crt和node.key) node.dir=node0 # 搭建新链时需配置 # FISCO-BCOS版本 fisco.version=2.7.2 # 搭建节点个数(默认两个) node.counts=nodeCounts
部署并启动所有服务
cd ~/webase-deploy/ && python3 deploy.py installAll
服务部署后,需要对各服务进行启停操作,可以使用以下命令:
# 一键部署 部署并启动所有服务 python3 deploy.py installAll 停止一键部署的所有服务 python3 deploy.py stopAll 启动一键部署的所有服务 python3 deploy.py startAll # 各子服务启停 启动FISCO-BCOS节点: python3 deploy.py startNode 停止FISCO-BCOS节点: python3 deploy.py stopNode 启动WeBASE-Web: python3 deploy.py startWeb 停止WeBASE-Web: python3 deploy.py stopWeb 启动WeBASE-Node-Manager: python3 deploy.py startManager 停止WeBASE-Node-Manager: python3 deploy.py stopManager 启动WeBASE-Sign: python3 deploy.py startSign 停止WeBASE-Sign: python3 deploy.py stopSign 启动WeBASE-Front: python3 deploy.py startFront 停止WeBASE-Front: python3 deploy.py stopFront # 可视化部署 部署并启动可视化部署的所有服务 python3 deploy.py installWeBASE 停止可视化部署的所有服务 python3 deploy.py stopWeBASE 启动可视化部署的所有服务 python3 deploy.py startWeBASE
WeBASE管理平台的访问:
http://{deployIP}:{webPort} 示例:http://localhost:5000
https://fisco-bcos-documentation.readthedocs.io/zh_CN/latest/docs/installation.html#fisco-bcos
https://fisco-bcos-documentation.readthedocs.io/zh_CN/latest/docs/webase/webase.html