部署说明

1. 依赖环境

环境版本
nginxnginx1.6或以上版本,安装请参考附录
WeBASE-Node-ManagerWeBASE-Node-Manager对应版本

2. 拉取代码

代码可以放在/data下面,执行命令:

  1. git clone https://github.com/WeBankBlockchain/WeBASE-Web.git
  2. # 若网络问题导致长时间无法下载,可尝试以下命令
  3. git clone https://gitee.com/WeBank/WeBASE-Web.git

进入目录:

  1. cd WeBASE-Web

2.1 下载solc-bin

执行脚本get_solc_js.sh会自动下载solc-bin,即下面v0.4.25.js等文件。 在WeBASE-Web/目录中直接执行脚本get_solc_js.sh((脚本与dist文件夹同级))

  1. bash ./get_solc_js.sh

等待脚本执行完成

  • 如果执行不成功,请使用下面的命令:

注意:当且仅当get_solc_js.sh脚本执行失败才需要执行下面的命令

  1. curl -#L https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/download/solidity/wasm/v0.4.25.js -o ./dist/static/js/v0.4.25.js
  2. curl -#L https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/download/solidity/wasm/v0.4.25-gm.js -o ./dist/static/js/v0.4.25-gm.js
  3. curl -#L https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/download/solidity/wasm/v0.5.2.js -o ./dist/static/js/v0.5.2.js
  4. curl -#L https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/download/solidity/wasm/v0.5.2-gm.js -o ./dist/static/js/v0.5.2-gm.js
  5. curl -#L https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/download/solidity/wasm/v0.6.10.js -o ./dist/static/js/v0.6.10.js
  6. curl -#L https://osp-1257653870.cos.ap-guangzhou.myqcloud.com/WeBASE/download/solidity/wasm/v0.6.10-gm.js -o ./dist/static/js/v0.6.10-gm.js

执行完后检查dist/static/js是否下载完这些js文件。

3. 拉取移动端代码

WeBASE新增了h5的移动端页面,支持手机浏览器访问。代码和WeBASE-Web放在同级目录

拉取代码

  1. git clone https://github.com/WeBankBlockchain/WeBASE-Web-Mobile.git
  2. # 若网络问题导致长时间无法下载,可尝试以下命令
  3. git clone https://gitee.com/WeBank/WeBASE-Web-Mobile.git

4. 修改配置

在docs目录下有配置文件nginx.conf,修改完后替换安装的nginx的配置文件nginx.conf(这里nginx安装配置文件在/usr/local/nginx/conf下面,如果这里没找到,可以到/etc下寻找,如有权限问题,请加上sudo)。

  • 修改配置:
  1. # 修改服务器ip,也可以使用域名
  2. sed -i "s%127.0.0.1%${your_ip}%g" docs/nginx.conf
  3. # 修改WeBASE-Web服务端口(端口需要开通策略且不能被占用)
  4. sed -i "s%5000%${your_port}%g" docs/nginx.conf
  5. # 修改静态文件路径(文件需要有权限访问)
  6. sed -i "s%/data/WeBASE-Web/dist%${your_file_dir}%g" docs/nginx.conf
  7. # 节点管理服务ip和端口
  8. sed -i "s%10.0.0.1:5001%${your_node_manager}%g" docs/nginx.conf
  • 复制配置文件nginx.conf到默认配置目录中
  • 也可以直接通过nginx -c docs/nginx.conf命令加载docs/nginx.conf配置
  1. cp -rf docs/nginx.conf /usr/local/nginx/conf

备注: 如果服务器已有nginx,可在原配置文件nginx.conf增加一个server:

  1. upstream node_mgr_server{
  2. server 10.0.0.1:5001; # 节点管理服务ip和端口
  3. }
  4. server {
  5. listen 5000 default_server; # 前端端口(端口需要开通策略且不能被占用)
  6. server_name 127.0.0.1; # 服务器ip,也可配置为域名
  7. location / {
  8. root /data/WeBASE-Web/dist; # 前端文件路径(文件需要有权限访问)
  9. # 下面是移动端nginx配置
  10. if ( $http_user_agent ~ "(MIDP)|(WAP)|(UP.Browser)|(Smartphone)|(Obigo)|(Mobile)|(AU.Browser)|(wxd.Mms)|(WxdB.Browser)|(CLDC)|(UP.Link)|(KM.Browser)|(UCWEB)|(SEMC-Browser)|(Mini)|(Symbian)|(Palm)|(Nokia)|(Panasonic)|(MOT-)|(SonyEricsson)|(NEC-)|(Alcatel)|(Ericsson)|(BENQ)|(BenQ)|(Amoisonic)|(Amoi-)|(Capitel)|(PHILIPS)|(SAMSUNG)|(Lenovo)|(Mitsu)|(Motorola)|(SHARP)|(WAPPER)|(LG-)|(LG/)|(EG900)|(CECT)|(Compal)|(kejian)|(Bird)|(BIRD)|(G900/V1.0)|(Arima)|(CTL)|(TDG)|(Daxian)|(DAXIAN)|(DBTEL)|(Eastcom)|(EASTCOM)|(PANTECH)|(Dopod)|(Haier)|(HAIER)|(KONKA)|(KEJIAN)|(LENOVO)|(Soutec)|(SOUTEC)|(SAGEM)|(SEC-)|(SED-)|(EMOL-)|(INNO55)|(ZTE)|(iPhone)|(Android)|(Windows CE)|(Wget)|(Java)|(curl)|(Opera)" )
  11. {
  12. root /data/WeBASE-Web-Mobile/dist;
  13. }
  14. index index.html index.htm;
  15. try_files $uri $uri/ /index.html =404;
  16. }
  17. include /etc/nginx/default.d/*.conf;
  18. location /mgr {
  19. proxy_pass http://node_mgr_server/;
  20. proxy_set_header Host $host;
  21. proxy_set_header X-Real-IP $remote_addr;
  22. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  23. }
  24. }

5. 启动nginx

启动命令:

  1. /usr/local/nginx/sbin/nginx # nginx在/usr/local目录下

检查nginx是否启动:

  1. ps -ef | grep nginx

6. 访问页面

  1. http://{deployIP}:{webPort}
  2. 示例:http://127.0.0.1:5000

备注:

  • 部署服务器IP和管理平台服务端口需对应修改,网络策略需开通
  • 默认账号密码:admin/Abcd1234
  • WeBASE管理平台使用说明请查看使用手册

7. 查看日志

  1. 进程日志:tail -f logs/access.log
  2. 错误日志:tail -f logs/eror.log