本项目是天玄区块链浏览器前端项目,使用框架react。 本教程脚本运行环境需要在 Linux 系统中进行,系统版本要求请见:硬件需求。
1.3.1 依赖环境
环境 | 版本 |
---|---|
nginx | nginx1.6或以上版本 |
node | node12~16 |
1.3.2 安装node
1.3.2.1 安装NVM
推荐使用nvm管理nodejs版本 使用命令安装nvm
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.38.0/install.sh | bash
1.3.2.2 更新会话
安装完成后,您需要关闭并重新打开终端,或者运行以下命令来更新会话以使用NVM
source ~/.bashrc
1.3.2.3 使用NVM安装指定版本的Node.js
现在,您可以使用NVM安装任何您想要的Node.js版本。例如,要安装Node.js 16.20.2,您可以运行:
nvm install 16.20.2
1.3.2.4 验证安装
安装完成后,您可以使用以下命令来检查Node.js是否安装成功:
node -v
这个命令应该会显示您刚刚安装的Node.js版本号。如果要切换版本可执行nvm use 版本号
1.3.2.5 直接安装nodejs
若不想安装nvm也可直接安装指定版本nodejs(本项目支持12到16版本),代码如下:
#ubuntu 安装命令
sudo apt -y install curl dirmngr apt-transport-https lsb-release ca-certificates
curl -sL https://deb.nodesource.com/setup_16.x | sudo -E bash -
sudo apt install nodejs
#centOS 安装命令
curl -sL https://rpm.nodesource.com/setup_16.x | bash -
yum install -y nodejs
1.3.3 拉取代码
git clone https://github.com/TianXuan-Chain/thanos-browser-frontend.git
1.3.4 打包
#进入项目文件夹
cd thanos-browser-frontend
#下载依赖(下载好node执行以下两步)
npm i
#打包
npm run build
注:如果依赖下载缓慢可以尝试切换淘宝镜像源,命令如下:
# 切换淘宝镜像源
npm config set registry https://registry.npmmirror.com
# 查看当前镜像源
npm config get registry
1.3.5 nginx反向代理
1.3.5.1 下载nginx(本文以Ubuntu系统为例,centos可参考网络教程)
安装nginx
#ubuntu 安装命令
sudo apt-get update
sudo apt-get install nginx
#centOS 安装命令
yum install nginx
执行命令时注意权限问题,如遇到,请加上sudo
查看安装版本
nginx -v
1.3.5.2 启动nginx
执行
nginx
一般输入后没有反馈,如果想确认nginx是否启动成功可以使用netstat -anput | grep nginx这个命令看看有没有nginx的端口占用。 然后在浏览器输入你对外的ip地址,如果页面出现了内容(一般是nginx页面)就说明你的nginx启动成功了。
1.3.5.3 将打包产物放到服务器上
#将dist文件复制到nginx
cp -r dist /usr/share/nginx/html
1.3.5.4 nginx配置
先找到默认的nginx配置文件路径
nginx -t
正常情况的信息输出:
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
其中 /usr/local/nginx/conf/nginx.conf 就是配置config文件路径
修改nginx.conf:
#路径根据nginx -t输出填写
vim /usr/local/nginx/conf/nginx.conf
- 修改前端服务的ip地址和端口,如示例中步骤1的localhost和80。
- 修改前端文件的路径,直接指向已拉取代码的dist目录。并且如果有需要请修改nginx的user配置,换成对应的user用户(有dist目录访问权限的用户),如示例中步骤2的/usr/share/nginx/html/dist。
- 修改后端服务的ip和端口(后端端口在thanos-browser-backend项目下的thanos-browser-web/src/main/resources/application.properties路径下的server.port配置查看)。如示例中步骤3的http://127.0.0.1:7776。 示例如下:
server {
listen 80; #步骤1、前端nginx监听端口
server_name localhost; #步骤1、前端地址,可配置为域名
location /browser {
proxy_pass http://127.0.0.1:7776; #步骤3、后端地址及端口,修改为浏览器后端地址
proxy_http_version 1.1;
proxy_set_header Connection "";
}
location / {
root /usr/share/nginx/html/dist; #步骤2、前端文件路径,修改为你上传dist包的路径地址
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
}
1.3.5.5 重启nginx
执行命令重启
nginx -s reload
重启之后没有反馈是正常现象,此时刷新一下页面即会显示浏览器网页。如果接口报错请注意查看nginx配置的后端地址是否正确,若前后端为两台服务器,请查看后端端口是否开放。