Skip to main content

部署 Spring Cloud Pig

关于 Spring Cloud Pig

  • 基于 Spring Cloud 2021 、Spring Boot 2.7、 OAuth2 的 RBAC 权限管理系统
  • 基于数据驱动视图的理念封装 element-plus,即使没有 vue 的使用经验也能快速上手
  • 提供 lambda 、stream api 、webflux 的生产实践

模块说明

pig-ui  -- https://gitee.com/log4j/pig-ui

pig -- https://gitee.com/log4j/pig
├── pig-auth -- 授权服务提供[3000]
└── pig-common -- 系统公共模块
├── pig-common-bom -- 全局依赖管理控制
├── pig-common-core -- 公共工具类核心包
├── pig-common-datasource -- 动态数据源包
├── pig-common-job -- xxl-job 封装
├── pig-common-log -- 日志服务
├── pig-common-mybatis -- mybatis 扩展封装
├── pig-common-seata -- 分布式事务
├── pig-common-security -- 安全工具类
├── pig-common-swagger -- 接口文档
├── pig-common-feign -- feign 扩展封装
└── pig-common-xss -- xss 安全封装
├── pig-register -- Nacos Server[8848]
├── pig-gateway -- Spring Cloud Gateway网关[9999]
└── pig-upms -- 通用用户权限管理模块
└── pig-upms-api -- 通用用户权限管理系统公共api模块
└── pig-upms-biz -- 通用用户权限管理系统业务处理模块[4000]
└── pig-visual
└── pig-monitor -- 服务监控 [5001]
├── pig-codegen -- 图形化代码生成 [5002]
├── pig-sentinel-dashboard -- 流量高可用 [5003]
└── pig-xxl-job-admin -- 分布式定时任务管理台 [5004]

通过源码部署 Spring Cloud Pig

本文档教程基于 Spring Cloud Pig v3.6.2 版本部署

一、部署 Mysql

  1. 基于源码创建组件,填写以下信息:
内容
组件名称自定义
组件英文名称自定义
仓库地址https://gitee.com/zhangbigqi/pig.git
子目录路径db
代码版本v3.6.2-1117
caution

这里使用了我的仓库地址,因为修改了一些默认配置,比如数据库密码、存储,如果你不想修改,可以使用原仓库地址

  1. 进入 Mysql 组件 -> 其他设置,修改组件部署类型为 有状态服务(Statefulset类型)
  2. 进入 Mysql 组件 -> 端口,点击端口别名修改为 MYSQL 并打开端口的对内服务。
info

以上变量名和变量值可以根据自己的需求进行修改。如果其他组件依赖了 Mysql,依赖中的变量会注入到依赖了 Mysql 组件中,参阅通信变量注入

tip

修改以上配置后构建 MySQL 组件

二、部署 Redis

通过开源应用商店部署 Redis,在开源应用商店中搜索 Redis 并安装。

三、部署 Pig 后端服务

  1. 基于源码创建组件,填写以下信息:
内容
组件名称自定义
组件英文名称自定义
仓库地址https://gitee.com/log4j/pig.git
代码版本: Tagv3.6.2
  1. 检测出多模块构建,进入多模块构建页面,勾选以下模块并创建。
    • 创建后,删除每个组件的默认端口,为每个组件添加对应的新端口和端口别名并打开端口的对内服务,如下:
组件端口端口别名
pig-register8848 9848 98498848端口别名: NACOS
pig-gateway9999端口别民: GATEWAY
pig-auth3000
pig-upms-biz4000
pig-codegen5002
pig-monitor5001
pig-sentinel-dashboard5003SENTINEL
pig-xxl-job-admin5004
  1. 编辑依赖关系,切换到 编排模式 拖动组件进行依赖关系建立。

  1. 进入 pig-register 组件内 -> 端口 -> 打开 8848 端口的对外服务,访问 Nacos 并登录,默认用户密码 nacos/nacos,修改以下配置文件内容:
# 编辑 application-dev.yml
spring:
cache:
type: redis
redis:
host: ${REDIS_HOST} #修改 redis host
cloud:
sentinel:
eager: true
transport:
dashboard: ${SENTINEL_HOST}:${SENTINEL_PORT} # 修改 sentinel host

# 编辑 pig-codegen-dev.yml
spring:
datasource:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: root
url: jdbc:mysql://${MYSQL_HOST}:${MYSQL_PORT}/pig_codegen?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai&nullCatalogMeansCurrent=true&allowPublicKeyRetrieval=true
# 修改 mysql host 和 port

# pig-upms-biz-dev.yml
spring:
datasource:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: root
url: jdbc:mysql://${MYSQL_HOST}:${MYSQL_PORT}/pig?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowMultiQueries=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai&nullCatalogMeansCurrent=true&allowPublicKeyRetrieval=true
# 修改 mysql host 和 port
tip

更新除 Mysql 和 Redis 外所有组件

四、部署 Pig-UI 前端

4.1、基于源码创建组件,填写以下信息:

内容
组件名称自定义
组件英文名称自定义
仓库地址https://gitee.com/zhangbigqi/pig-ui.git
代码版本v3.6.2-1117
caution

这里使用了我的仓库地址,因为修改了一些默认配置,比如增加了 nodestatic.json web.conf,参阅 部署Vue、React前端

4.2、创建组件后,进入 pig-ui 组件内 -> 构建源 -> 源码构建参数设置,修改 Node 版本为 16.15.0,确定修改并构建组件

4.3、编辑依赖关系,切换到 编排模式 拖动组件进行依赖关系建立,将 pig-ui 依赖 pig-gateway

4.4、进入 pig-ui 组件内 -> 环境配置 -> 添加配置文件,添加以下配置文件:

  • 配置文件名称:自定义
  • 配置文件路径:/app/nginx/conf.d/web.conf
  • 配置文件内容如下:
server {
listen 80;

gzip on;
gzip_static on; # 需要http_gzip_static_module 模块
gzip_min_length 1k;
gzip_comp_level 4;
gzip_proxied any;
gzip_types text/plain text/xml text/css;
gzip_vary on;
gzip_http_version 1.0; #兼容多层nginx 反代
gzip_disable "MSIE [1-6]\.(?!.*SV1)";

# 打包好的dist目录文件,放置到这个目录下
root /app/www;

# 注意维护新增微服务,gateway 路由前缀
location ~* ^/(code|auth|admin|gen) {
proxy_pass http://${GATEWAY_HOST}:${GATEWAY_PORT};
#proxy_set_header Host $http_host;
proxy_connect_timeout 15s;
proxy_send_timeout 15s;
proxy_read_timeout 15s;
proxy_set_header X-Forwarded-Proto http;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

# 避免端点安全问题
if ($request_uri ~ "/actuator"){
return 403;
}
}

4.5、删除默认端口,新增 80 端口并打开对外服务。

4.6、更新组件并访问 pig-ui 进行验证。

最终拓扑图