编译运行
1 编译运行(v1.7.0 及以前)
1.1 编译前端
cd frontend
npm i
注意:国内使用 npm 时经常会遇到网络问题,可以考虑将 npm 源替换为国内的源。
可以参考文档 https://segmentfault.com/a/1190000023314583。
1.2 运行前端
前端运行有两种方式:
- npm 运行(适用于开发场景)
- nginx 运行(适用于稳定运行场景)
方式一 npm 运行:
进入前端目录 frontend,修改 .env.development 文件中的 VUE_APP_BASE_API,将 IP 地址设置为本机 IP,后端默认运行端口为 8081:
修改后执行命令运行:
npm run serve
注意: 以 npm 方式运行前端,默认会运行在本地的 9528 端口上,通过浏览器访问 http://ip:9528 即可。
方式二 Nginx 运行:
以 Nginx、Apache 等运行前端,则修改 .env.production 文件中的 VUE_APP_BASE_API,将 IP 地址设置为本机 IP,后端默认运行端口为 8081,如下示例配置 Nginx 运行。
修改后执行命令进行编辑,生成 dist 目录:
npm run build
# 将 dist 目录放置到 /opt/dataease/frontend/dist
mkdir -p /opt/dataease/frontend
cp -r dist /opt/dataease/frontend/dist
配置 nginx:
此处假设 DataEase 前端运行在 8000 端口,后端运行在 8081,且 DataEase 前端编译后生成的 dist 目录存放到路径为 /opt/dataease/frontend/dist,相应的 nginx 配置如下:
server {
listen 8000;
server_name localhost;
location / {
root /opt/dataease/frontend/dist;
index index.html index.htm;
}
# 此处为公共链接请求转发,8081 为后端运行端口
location /link/ {
proxy_pass http://$host:8081;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
注意: nginx 默认以 nobody 用户身份运行,可能会遇到 403 的错误。可以授予 dist 目录访问权限,或者将 nginx 设置为 root 用户运行。
1.3 编译后端
进入后端代码目录 backend,修改 pom.xml,去掉默认的打包前端代码的部分:
执行编译命令:
mvn clean package
注意: 在编译后端代码时如遇到依赖无法下载的问题,可以在百度网盘上下载一下最小化的 dataease 依赖包。链接: https://pan.baidu.com/s/1fWv_ze-QKUew3ND4NAdt8Q 提取码: rpzi
1.4 运行后端
后端代码编译完成后,会在 backend/target 目录下生成一个 backend-1.4.0.jar,可以通过命令运行后端:
nohup java -jar backend-1.4.0.jar &
2 编译运行(v1.8.0 及以后)
2.1 源码编译打包
打包 backend:
在backend目录下,执行下面命令。
mvn clean package -Pstage
注意:
- 在 backend 目录下,不是 dataease 目录;
- 命令一定要加 -Pstage;
- 运行文件为 target/backend-1.8.0.jar。
打包 frontend:
在 frontend 目录下,执行下面命令,注意命令后缀。
npm run build:stage
打包 mobile:
在 mobile 目录下,执行下面命令,注意命令后缀。
npm run build:stage
2.2 Nginx 配置
假设各个文件分别按如下路径放置:
- frontend 编译后文件存放目录 /opt/dataease/frontend/dist
- mobile 编译后文件存放目录 /opt/mobile/frontend/dist
- nginx 配置文件路径 /usr/local/etc/nginx/nginx.conf
在dataease工程目录下执行:
mkdir -p /opt/dataease/frontend/dist
cp -r frontend/dist/* /opt/dataease/frontend/dist
mkdir -p /opt/dataease/mobile/dist
cp -r mobile/dist/* /opt/dataease/mobile/dist
mv /opt/dataease/mobile/dist/index.html /opt/dataease/mobile/dist/app.html
修改 nginx.conf 配置:
server {
listen 8000;
server_name localhost;
location / {
root /opt/dataease/frontend/dist/;
index index.html;
}
location /app.html {
root /opt/dataease/mobile/dist/;
}
location /de-app/ {
alias /opt/dataease/mobile/dist/;
}
location /de-api/ {
proxy_pass http://localhost:8081/de-api/;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host:8000;
server_name_in_redirect on;
}
}