dengzedong
2024-12-31 5caafd80dd4005f6ec6c73cdcf94611befbb61b5
提交 | 用户 | 时间
e7c126 1 spring:
4a47e4 2   application:
H 3     name: bpm-server
4
5   profiles:
6     active: @profiles.active@
7
8   cloud:
9     nacos:
10       server-addr: @nacos.server@ # Nacos 服务器地址
11       username: @nacos.username@
12       password: @nacos.password@
13       discovery: # 【配置中心】配置项
14         namespace: ${spring.profiles.active}
15         group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
16         metadata:
17           version: @nacos.metadata.version@ # 服务实例的版本号,可用于灰度发布
18       config: # 【注册中心】配置项
19         namespace: ${spring.profiles.active}
20         group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
21
e7c126 22   main:
H 23     allow-circular-references: true # 允许循环依赖,因为项目是三层架构,无法避免这个情况。
24     allow-bean-definition-overriding: true # 允许 Bean 覆盖,例如说 Feign 等会存在重复定义的服务
4a47e4 25
H 26   config:
27     import:
28       - optional:classpath:application-${spring.profiles.active}.yaml # 加载【本地】配置
29       - optional:nacos:${spring.application.name}-${spring.profiles.active}.yaml # 加载【Nacos】的配置
e7c126 30
H 31   # Servlet 配置
32   servlet:
33     # 文件上传相关配置项
34     multipart:
35       max-file-size: 16MB # 单个文件大小
36       max-request-size: 32MB # 设置总上传的文件大小
37   mvc:
38     pathmatch:
39       matching-strategy: ANT_PATH_MATCHER # 解决 SpringFox 与 SpringBoot 2.6.x 不兼容的问题,参见 SpringFoxHandlerProviderBeanPostProcessor 类
40
41   # Jackson 配置项
42   jackson:
43     serialization:
44       write-dates-as-timestamps: true # 设置 LocalDateTime 的格式,使用时间戳
45       write-date-timestamps-as-nanoseconds: false # 设置不使用 nanoseconds 的格式。例如说 1611460870.401,而是直接 1611460870401
46       write-durations-as-timestamps: true # 设置 Duration 的格式,使用时间戳
47       fail-on-empty-beans: false # 允许序列化无属性的 Bean
48
49   # Cache 配置项
50   cache:
51     type: REDIS
52     redis:
53       time-to-live: 1h # 设置过期时间为 1 小时
4a47e4 54
H 55 server:
56   port: 48083
57
58 logging:
59   file:
60     name: @log.path@/logs/${spring.application.name}.log # 日志文件名,全路径
e7c126 61
H 62 --- #################### 接口文档配置 ####################
63
64 springdoc:
65   api-docs:
66     enabled: true # 1. 是否开启 Swagger 接文档的元数据
67     path: /v3/api-docs
68   swagger-ui:
69     enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面
70     path: /swagger-ui.html
71   default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档
72
73 knife4j:
74   enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面
75   setting:
76     language: zh_cn
77
78 # 工作流 Flowable 配置
79 flowable:
80   # 1. false: 默认值,Flowable 启动时,对比数据库表中保存的版本,如果不匹配。将抛出异常
81   # 2. true: 启动时会对数据库中所有表进行更新操作,如果表存在,不做处理,反之,自动创建表
82   # 3. create_drop: 启动时自动创建表,关闭时自动删除表
83   # 4. drop_create: 启动时,删除旧表,再创建新表
84   database-schema-update: true # 设置为 false,可通过 https://github.com/flowable/flowable-sql 初始化
85   db-history-used: true # flowable6 默认 true 生成信息表,无需手动设置
86   check-process-definitions: false # 设置为 false,禁用 /resources/processes 自动部署 BPMN XML 流程
87   history-level: audit # full:保存历史数据的最高级别,可保存全部流程相关细节,包括流程流转各节点参数
88
89 # MyBatis Plus 的配置项
90 mybatis-plus:
91   configuration:
92     map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。
4a47e4 93     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
e7c126 94   global-config:
H 95     db-config:
96       id-type: NONE # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。
97       #      id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库
98       #      id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库
99       #      id-type: ASSIGN_ID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解
100       logic-delete-value: 1 # 逻辑已删除值(默认为 1)
101       logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
102     banner: false # 关闭控制台的 Banner 打印
103   type-aliases-package: ${iailab.info.base-package}.dal.dataobject
104   encryptor:
105     password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成
106
107 mybatis-plus-join:
108   banner: false # 关闭控制台的 Banner 打印
109
110 # Spring Data Redis 配置
111 spring:
112   data:
113     redis:
114       repositories:
115         enabled: false # 项目未使用到 Spring Data Redis 的 Repository,所以直接禁用,保证启动速度
116
117 # VO 转换(数据翻译)相关
118 easy-trans:
119   is-enable-global: true # 启用全局翻译(拦截所有 SpringMVC ResponseBody 进行自动翻译 )。如果对于性能要求很高可关闭此配置,或通过 @IgnoreTrans 忽略某个接口
120   is-enable-cloud: false # 禁用 TransType.RPC 微服务模式
121
122 --- #################### RPC 远程调用相关配置 ####################
123
124 --- #################### MQ 消息队列相关配置 ####################
125
126 --- #################### 定时任务相关配置 ####################
127
128 xxl:
129   job:
130     executor:
131       appname: ${spring.application.name} # 执行器 AppName
4a47e4 132       logpath: @log.path@/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径
e7c126 133     accessToken: default_token # 执行器通讯TOKEN
H 134
135 --- #################### 平台相关配置 ####################
136
137 iailab:
138   info:
139     version: 1.0.0
140     base-package: com.iailab.module.bpm
141   web:
142     admin-ui:
08e3e8 143       url:  # Admin 管理后台 UI 的地址
325d2f 144   xss:
H 145     enable: false
146     exclude-urls: # 如下 url,仅仅是为了演示,去掉配置也没关系
147       - ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求
e7c126 148   swagger:
H 149     title: 管理后台
150     description: 提供管理员管理的所有功能
151     version: ${iailab.info.version}
152   tenant: # 多租户相关配置项
153     enable: true
154
155 debug: false