区块链部署和运维—实战训练

一.宠物商店领养项目实施部署练习

1.预操作:

第一步先检查是否有包含“FISCO”关键词的进程存在

ps -ef |grep fisco

图片[1] - 区块链部署和运维—实战训练 - MaxSSL

如果没有相关进程正在启动

首先启动FISCO BCOS

cd fisco-bcosbash nodes/127.0.0.1/start_all.sh

图片[2] - 区块链部署和运维—实战训练 - MaxSSL

启动WeBASE-Front

cd WeBASE-Frontcd dist/bash start.sh

图片[3] - 区块链部署和运维—实战训练 - MaxSSL

监控WeBASE-Front启动情况

tail -f log/WeBASE-Front.log

图片[4] - 区块链部署和运维—实战训练 - MaxSSL

通过网页验证:

图片[5] - 区块链部署和运维—实战训练 - MaxSSL

2.配置与启动软件应用
第一步:

1. 打开虚拟机,用mobaxterm等软件连接虚拟机,并创建AdoptionProject

mkdir AdoptionProject

图片[6] - 区块链部署和运维—实战训练 - MaxSSL

第二步:

2. 将软件应用的前后端代码拷贝至虚拟环境的AdoptionProject目录

前端

后端

图片[7] - 区块链部署和运维—实战训练 - MaxSSL

3.解压前后端代码
第一步:解压前端
cd AdoptionProjectunzip pet-store-front-master.zip

图片[8] - 区块链部署和运维—实战训练 - MaxSSL

第二步:解压后端
unzip pet-store-flask-master.zip

图片[9] - 区块链部署和运维—实战训练 - MaxSSL

4. 部署Adoption智能合约
第一步:

打开WeBASE-Front网页,找到Adoption智能合约,分别“保存”->“编译”->“部署”,使用“admin”进行部署

图片[10] - 区块链部署和运维—实战训练 - MaxSSL

5.创建虚拟环境

现在开始首先部署软件应用后端(pet-store-flask),进入~/AdoptionProject/pet-store-flask-master,使用virtualenv创建虚拟环境

cd pet-store-flask-master/python3 -m virtualenv venv

图片[11] - 区块链部署和运维—实战训练 - MaxSSL

6.安装依赖

进入后端文件,使用pip install -r requirements.txt安装后端所有依赖

Cd pet-store-flask-master/pip install -r requirements.txt

图片[12] - 区块链部署和运维—实战训练 - MaxSSL

有如下输出说明执行正确

图片[13] - 区块链部署和运维—实战训练 - MaxSSL

7.修改config文件

修改后端项目中对应的config.py文件,其中包括admin_address,contract_address

vim config.py

图片[14] - 区块链部署和运维—实战训练 - MaxSSL

图片[15] - 区块链部署和运维—实战训练 - MaxSSL

图片[16] - 区块链部署和运维—实战训练 - MaxSSL

图片[17] - 区块链部署和运维—实战训练 - MaxSSL

8. 找到app.py将端口改成8081

8080端口已经被占用,需要换一个端口

vim app.py

图片[18] - 区块链部署和运维—实战训练 - MaxSSL

图片[19] - 区块链部署和运维—实战训练 - MaxSSL

图片[20] - 区块链部署和运维—实战训练 - MaxSSL

9. 通过nohup启动后端
nohup python app.py &

图片[21] - 区块链部署和运维—实战训练 - MaxSSL

10. 使用tail监控
tail -f nohup.out

图片[22] - 区块链部署和运维—实战训练 - MaxSSL

11. 开始部署前端

进入pet-store-front-master目录,使用npm install安装前端依赖

npm install

图片[23] - 区块链部署和运维—实战训练 - MaxSSL

安装执行成功有如下输出:

图片[24] - 区块链部署和运维—实战训练 - MaxSSL

12. 通过npm生成前端项目的静态文件
npm run build

生成静态文件:

图片[25] - 区块链部署和运维—实战训练 - MaxSSL

前端项目静态文件执行成功后会生成dist目录

图片[26] - 区块链部署和运维—实战训练 - MaxSSL

13. 配置nginx

通过反向代理的形式将8022端口指向本地pet-store-master目录中的dist子目录

获取nginx.conf地址:sudo nginx -t

sudo nginx -t

图片[27] - 区块链部署和运维—实战训练 - MaxSSL

修改nginx.conf加上通过8022反向代理到本地dist目录的配置

sudo vim /etc/nginx/nginx.conf

图片[28] - 区块链部署和运维—实战训练 - MaxSSL

图片[29] - 区块链部署和运维—实战训练 - MaxSSL

在nginx.conf的http上下文中加入server配置,具体内容如下:

图片[30] - 区块链部署和运维—实战训练 - MaxSSL

保存nginx.conf后,使用命令让nginx工具重新加载nginx.conf

sudo nginx -s reload

图片[31] - 区块链部署和运维—实战训练 - MaxSSL

检查8022端口占用情况:

图片[32] - 区块链部署和运维—实战训练 - MaxSSL

检查网页使用情况

图片[33] - 区块链部署和运维—实战训练 - MaxSSL

14. 验证功能

(1)注册

首先进入注册页面:

图片[34] - 区块链部署和运维—实战训练 - MaxSSL

在webase-front中复制一个用户的地址,进行注册:

图片[35] - 区块链部署和运维—实战训练 - MaxSSL

有如下输出说明注册成功

图片[36] - 区块链部署和运维—实战训练 - MaxSSL

(2)登录

进入登录页

图片[37] - 区块链部署和运维—实战训练 - MaxSSL

将刚刚注册的用户地址,在登录页复制后登录,有如下输出说明登录成功:

图片[38] - 区块链部署和运维—实战训练 - MaxSSL

二.基于容器技术的区块链系统部署与验证

一、案例设计:

图片[39] - 区块链部署和运维—实战训练 - MaxSSL

二、预操作
第一步:修改docker源为国内
sudo vim /etc/docker/daemon.json
第二步:配置内容
{"registry-mirrors": ["http://hub-mirror.c.163.com","https://docker.mirrors.ustc.edu.cn","https://registry.docker-cn.com"]}
第三步:重启docker
sudo service docker restart
三.部署操作
第一部分:服务端配置

工程目录(:~/AdoptionProject /pet-store-flask-master),修改config.py中admin_address(部署合约用户地址)和contract_address(合约地址),webase_host(局域网下webase-front访问ip)

vim pet-store-flask-master/config.py

图片[40] - 区块链部署和运维—实战训练 - MaxSSL

图片[41] - 区块链部署和运维—实战训练 - MaxSSL图片[42] - 区块链部署和运维—实战训练 - MaxSSL

图片[43] - 区块链部署和运维—实战训练 - MaxSSL

第二步:创建BackDockerfile
cd AdoptionProjectvim BackDockerfile#添加以下内容FROM python:3.8ADD ./pet-store-flask-master /root/pet-storeADD ./.pip /root/.pipWORKDIR /root/pet-storeRUN pip install -r requirements.txtEXPOSE 8081CMD /bin/bash -c "python app.py"

图片[44] - 区块链部署和运维—实战训练 - MaxSSL

复制用户根目录(~)中的.pip目录到AdoptionProject目录中

cp -r .pip AdoptionProject/

图片[45] - 区块链部署和运维—实战训练 - MaxSSL

修改后端代码(~/AdoptionProject/pet-store-flask-master/app.py)在最后添加host配置:

vim pet-store-flask-master/app.py

图片[46] - 区块链部署和运维—实战训练 - MaxSSL

第三步:生成back:v1
docker build -f BackDockerfile -t back:v1 .
图片[47] - 区块链部署和运维—实战训练 - MaxSSL

图片[48] - 区块链部署和运维—实战训练 - MaxSSL

第四步:验证自定义镜像
docker images

图片[49] - 区块链部署和运维—实战训练 - MaxSSL

第五步:运行后端代码对应容器验证
docker run -itd --name pet-store-back-p 8081:8081 back:v1

图片[50] - 区块链部署和运维—实战训练 - MaxSSL使用docker ps,验证

图片[51] - 区块链部署和运维—实战训练 - MaxSSL

使用netstat -nlp |grep 8081,验证进程是否正在运行

图片[52] - 区块链部署和运维—实战训练 - MaxSSL

第六步:使用postman验证

验证url为:“/”接口

#ip地址192.168.200.100:8081/

图片[53] - 区块链部署和运维—实战训练 - MaxSSL

验证/user/register

先在webase-front中创建一个test4用户

图片[54] - 区块链部署和运维—实战训练 - MaxSSL

使用postman验证,url: /user/register” />你创建的用户地址]

图片[55] - 区块链部署和运维—实战训练 - MaxSSL

第七步:客户端生成静态文件

工程目录(~/AdoptionProject/pet-store-front-master)

进入此目录确认存在dist文件,

图片[56] - 区块链部署和运维—实战训练 - MaxSSL

如果dist文件夹不存在,那么使用如下命令进行生成:

npm run build

图片[57] - 区块链部署和运维—实战训练 - MaxSSL

第八步:复制配置nginx.conf
cp /etc/nginx/nginx.conf .
图片[58] - 区块链部署和运维—实战训练 - MaxSSL
第九步:修改nginx.conf文件
vim nginx.conf#配置文件内容server{listen8020;server_name localhost;root/root/dist;location / {try_files $uri $uri/ @router;index index.html;}location /api/ {proxy_pass http://back:8081/;}location @router{rewrite ^.*$ /index.html last;}}
图片[59] - 区块链部署和运维—实战训练 - MaxSSL
第十步:配置docker-compose.yml
vim docker-compose.yml#配置文件内容version: '3.3'services:back:image: back:v1container_name: petstore_backports:- 8081:8081front:image: nginxcontainer_name: petstore_frontvolumes:- /home/arthur/AdoptionProject/pet-store-front-master/dist:/root/dist- ./nginx.conf:/etc/nginx/nginx.confports:- 8020:8020
图片[60] - 区块链部署和运维—实战训练 - MaxSSL
第十一步:使用docker-compose up启动项目
docker-compose up
图片[61] - 区块链部署和运维—实战训练 - MaxSSL
第十二步:验证启动结果

访问{虚拟机IP}:8020

(1)注册

图片[62] - 区块链部署和运维—实战训练 - MaxSSL

(2)登录

图片[63] - 区块链部署和运维—实战训练 - MaxSSL图片[64] - 区块链部署和运维—实战训练 - MaxSSL

(3)领养

图片[65] - 区块链部署和运维—实战训练 - MaxSSL

其他报错信息 :

1.如果出现以下报错信息,请重启虚拟机

图片[66] - 区块链部署和运维—实战训练 - MaxSSL
2.如果出现以下报错信息,先停止镜像,在删除镜像,然后重新生成bave:v1

图片[67] - 区块链部署和运维—实战训练 - MaxSSL

docker stop 9b653e4f612a docker rm 9b653e4f612a 

图片[68] - 区块链部署和运维—实战训练 - MaxSSL

3.如果运行后端时出现以下报错信息,表示端口被占用

图片[69] - 区块链部署和运维—实战训练 - MaxSSL

#查看被占用的端口ps aux | grep python#杀掉这个端口kill 39859

图片[70] - 区块链部署和运维—实战训练 - MaxSSL

4..如果启动项目遇到这个问题说明端口被占用了

图片[71] - 区块链部署和运维—实战训练 - MaxSSL先使用docker ps查看被占用的端口

图片[72] - 区块链部署和运维—实战训练 - MaxSSL

在停止对项目的启动:docker-compose down

图片[73] - 区块链部署和运维—实战训练 - MaxSSL

在停止被占用的端口 :docker stop pet-store-back

图片[74] - 区块链部署和运维—实战训练 - MaxSSL

在重新启动项目:docker-compose up

图片[61] - 区块链部署和运维—实战训练 - MaxSSL

5.如果打开浏览器报500的错误,且终端中出现以下内容,要修改配置文件nginx.conf

图片[76] - 区块链部署和运维—实战训练 - MaxSSL

vimnginx.conf

图片[77] - 区块链部署和运维—实战训练 - MaxSSL

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享