编译运行

1 编译运行(v1.7.0 及以前)

1.1 编译前端

  1. cd frontend
  2. npm i

注意:国内使用 npm 时经常会遇到网络问题,可以考虑将 npm 源替换为国内的源。
可以参考文档 https://segmentfault.com/a/1190000023314583

npm-install

1.2 运行前端

前端运行有两种方式:

  • npm 运行(适用于开发场景)
  • nginx 运行(适用于稳定运行场景)

方式一 npm 运行:
进入前端目录 frontend,修改 .env.development 文件中的 VUE_APP_BASE_API,将 IP 地址设置为本机 IP,后端默认运行端口为 8081:

frontend-development-env

修改后执行命令运行:

  1. npm run serve

注意: 以 npm 方式运行前端,默认会运行在本地的 9528 端口上,通过浏览器访问 http://ip:9528 即可。

方式二 Nginx 运行:
以 Nginx、Apache 等运行前端,则修改 .env.production 文件中的 VUE_APP_BASE_API,将 IP 地址设置为本机 IP,后端默认运行端口为 8081,如下示例配置 Nginx 运行。

frontend-production-env

修改后执行命令进行编辑,生成 dist 目录:

  1. npm run build
  2. # 将 dist 目录放置到 /opt/dataease/frontend/dist
  3. mkdir -p /opt/dataease/frontend
  4. cp -r dist /opt/dataease/frontend/dist

配置 nginx:
此处假设 DataEase 前端运行在 8000 端口,后端运行在 8081,且 DataEase 前端编译后生成的 dist 目录存放到路径为 /opt/dataease/frontend/dist,相应的 nginx 配置如下:

  1. server {
  2. listen 8000;
  3. server_name localhost;
  4. location / {
  5. root /opt/dataease/frontend/dist;
  6. index index.html index.htm;
  7. }
  8. # 此处为公共链接请求转发,8081 为后端运行端口
  9. location /link/ {
  10. proxy_pass http://$host:8081;
  11. proxy_set_header X-Real-IP $remote_addr;
  12. proxy_set_header Host $http_host;
  13. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  14. }
  15. }

注意: nginx 默认以 nobody 用户身份运行,可能会遇到 403 的错误。可以授予 dist 目录访问权限,或者将 nginx 设置为 root 用户运行。

1.3 编译后端

进入后端代码目录 backend,修改 pom.xml,去掉默认的打包前端代码的部分:

remove-frontend

执行编译命令:

  1. mvn clean package

注意: 在编译后端代码时如遇到依赖无法下载的问题,可以在百度网盘上下载一下最小化的 dataease 依赖包。链接: https://pan.baidu.com/s/1fWv_ze-QKUew3ND4NAdt8Q 提取码: rpzi

1.4 运行后端

后端代码编译完成后,会在 backend/target 目录下生成一个 backend-1.4.0.jar,可以通过命令运行后端:

  1. nohup java -jar backend-1.4.0.jar &

2 编译运行(v1.8.0 及以后)

2.1 源码编译打包

打包 backend:
在backend目录下,执行下面命令。

  1. mvn clean package -Pstage

注意:

  1. 在 backend 目录下,不是 dataease 目录;
  2. 命令一定要加 -Pstage;
  3. 运行文件为 target/backend-1.8.0.jar。

打包 frontend:
在 frontend 目录下,执行下面命令,注意命令后缀。

  1. npm run build:stage

打包 mobile:
在 mobile 目录下,执行下面命令,注意命令后缀。

  1. 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工程目录下执行:

  1. mkdir -p /opt/dataease/frontend/dist
  2. cp -r frontend/dist/* /opt/dataease/frontend/dist
  3. mkdir -p /opt/dataease/mobile/dist
  4. cp -r mobile/dist/* /opt/dataease/mobile/dist
  5. mv /opt/dataease/mobile/dist/index.html /opt/dataease/mobile/dist/app.html

修改 nginx.conf 配置:

  1. server {
  2. listen 8000;
  3. server_name localhost;
  4. location / {
  5. root /opt/dataease/frontend/dist/;
  6. index index.html;
  7. }
  8. location /app.html {
  9. root /opt/dataease/mobile/dist/;
  10. }
  11. location /de-app/ {
  12. alias /opt/dataease/mobile/dist/;
  13. }
  14. location /de-api/ {
  15. proxy_pass http://localhost:8081/de-api/;
  16. proxy_set_header X-Real-IP $remote_addr;
  17. proxy_set_header Host $host:8000;
  18. server_name_in_redirect on;
  19. }
  20. }

2.3 运行测试

访问 http://localhost:8000