潘志宝
2024-12-16 df99e46312fdd5ee830f1451e478f6658e09f9ed
提交 | 用户 | 时间
4a47e4 1 --- #################### 注册中心 + 配置中心相关配置 ####################
e7c126 2 spring:
d9f9ba 3   application:
H 4     name: system-server
5
6   profiles:
4a47e4 7     active: @profiles.active@
H 8
9   cloud:
10     nacos:
11       server-addr: @nacos.server@ # Nacos 服务器地址
12       username: @nacos.username@
13       password: @nacos.password@
14       discovery: # 【配置中心】配置项
15         namespace: @profiles.active@
16         group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
17         metadata:
18           version: @nacos.metadata.version@ # 服务实例的版本号,可用于灰度发布
19       config: # 【注册中心】配置项
20         namespace: @profiles.active@
21         group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
d9f9ba 22
e7c126 23   main:
H 24     allow-circular-references: true # 允许循环依赖,因为项目是三层架构,无法避免这个情况。
25     allow-bean-definition-overriding: true # 允许 Bean 覆盖,例如说 Feign 等会存在重复定义的服务
d9f9ba 26
H 27   config:
28     import:
29       - optional:classpath:application-${spring.profiles.active}.yaml # 加载【本地】配置
30       - optional:nacos:${spring.application.name}-${spring.profiles.active}.yaml # 加载【Nacos】的配置
e7c126 31
H 32   # Servlet 配置
33   servlet:
34     # 文件上传相关配置项
35     multipart:
36       max-file-size: 16MB # 单个文件大小
37       max-request-size: 32MB # 设置总上传的文件大小
38   mvc:
39     pathmatch:
40       matching-strategy: ANT_PATH_MATCHER # 解决 SpringFox 与 SpringBoot 2.6.x 不兼容的问题,参见 SpringFoxHandlerProviderBeanPostProcessor 类
41
42   # Jackson 配置项
43   jackson:
44     serialization:
45       write-dates-as-timestamps: true # 设置 LocalDateTime 的格式,使用时间戳
46       write-date-timestamps-as-nanoseconds: false # 设置不使用 nanoseconds 的格式。例如说 1611460870.401,而是直接 1611460870401
47       write-durations-as-timestamps: true # 设置 Duration 的格式,使用时间戳
48       fail-on-empty-beans: false # 允许序列化无属性的 Bean
49
50   # Cache 配置项
51   cache:
52     type: REDIS
53     redis:
54       time-to-live: 1h # 设置过期时间为 1 小时
d9f9ba 55
H 56 server:
57   port: 48081
58
59 logging:
60   file:
4a47e4 61     name: @log.path@/logs/${spring.application.name}.log # 日志文件名,全路径
e7c126 62
H 63 --- #################### 接口文档配置 ####################
64
65 springdoc:
66   api-docs:
67     enabled: true # 1. 是否开启 Swagger 接文档的元数据
68     path: /v3/api-docs
69   swagger-ui:
70     enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面
71     path: /swagger-ui.html
08e3e8 72   default-flat-param-object: true
e7c126 73
H 74 knife4j:
75   enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面
76   setting:
77     language: zh_cn
78
79 # MyBatis Plus 的配置项
80 mybatis-plus:
81   configuration:
82     map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。
83   global-config:
84     db-config:
85       id-type: AUTO # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。
86       #      id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库
87       #      id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库
88       #      id-type: ASSIGN_ID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解
89       logic-delete-value: 1 # 逻辑已删除值(默认为 1)
90       logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
91     banner: false # 关闭控制台的 Banner 打印
92   type-aliases-package: ${iailab.info.base-package}.dal.dataobject
93   encryptor:
94     password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成
95
96 mybatis-plus-join:
97   banner: false # 关闭控制台的 Banner 打印
98
99 # Spring Data Redis 配置
100 spring:
101   data:
102     redis:
103       repositories:
104         enabled: false # 项目未使用到 Spring Data Redis 的 Repository,所以直接禁用,保证启动速度
105
106 # VO 转换(数据翻译)相关
107 easy-trans:
108   is-enable-global: true # 启用全局翻译(拦截所有 SpringMVC ResponseBody 进行自动翻译 )。如果对于性能要求很高可关闭此配置,或通过 @IgnoreTrans 忽略某个接口
109   is-enable-cloud: false # 禁用 TransType.RPC 微服务模式
110
111 --- #################### RPC 远程调用相关配置 ####################
112
113 --- #################### 消息队列相关 ####################
114
115 # rocketmq 配置项,对应 RocketMQProperties 配置类
116 rocketmq:
117   # Producer 配置项
118   producer:
119     group: ${spring.application.name}_PRODUCER # 生产者分组
120
121 spring:
122   # Kafka 配置项,对应 KafkaProperties 配置类
123   kafka:
124     # Kafka Producer 配置项
125     producer:
126       acks: 1 # 0-不应答。1-leader 应答。all-所有 leader 和 follower 应答。
127       retries: 3 # 发送失败时,重试发送的次数
128       value-serializer: org.springframework.kafka.support.serializer.JsonSerializer # 消息的 value 的序列化
129     # Kafka Consumer 配置项
130     consumer:
08e3e8 131       auto-offset-reset: earliest
e7c126 132       value-deserializer: org.springframework.kafka.support.serializer.JsonDeserializer
H 133       properties:
134         spring.json.trusted.packages: '*'
135     # Kafka Consumer Listener 监听器配置
136     listener:
137       missing-topics-fatal: false # 消费监听接口监听的主题不存在时,默认会报错。所以通过设置为 false ,解决报错
138
139 --- #################### 定时任务相关配置 ####################
140
141 xxl:
142   job:
143     executor:
144       appname: ${spring.application.name} # 执行器 AppName
4a47e4 145       logpath: @log.path@/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径
e7c126 146     accessToken: default_token # 执行器通讯TOKEN
H 147
148 --- #################### 验证码相关配置 ####################
149
150 aj:
151   captcha:
152     jigsaw: classpath:images/jigsaw # 滑动验证,底图路径,不配置将使用默认图片;以 classpath: 开头,取 resource 目录下路径
153     pic-click: classpath:images/pic-click # 滑动验证,底图路径,不配置将使用默认图片;以 classpath: 开头,取 resource 目录下路径
154     cache-type: redis # 缓存 local/redis...
155     cache-number: 1000 # local 缓存的阈值,达到这个值,清除缓存
156     timing-clear: 180 # local定时清除过期缓存(单位秒),设置为0代表不执行
157     type: blockPuzzle # 验证码类型 default两种都实例化。 blockPuzzle 滑块拼图 clickWord 文字点选
158     water-mark: iailab # 右下角水印文字(我的水印),可使用 https://tool.chinaz.com/tools/unicode.aspx 中文转 Unicode,Linux 可能需要转 unicode
159     interference-options: 0 # 滑动干扰项(0/1/2)
160     req-frequency-limit-enable: false # 接口请求次数一分钟限制是否开启 true|false
161     req-get-lock-limit: 5 # 验证失败5次,get接口锁定
162     req-get-lock-seconds: 10 # 验证失败后,锁定时间间隔
163     req-get-minute-limit: 30 # get 接口一分钟内请求数限制
164     req-check-minute-limit: 60 # check 接口一分钟内请求数限制
165     req-verify-minute-limit: 60 # verify 接口一分钟内请求数限制
166
167 --- #################### 平台相关配置 ####################
168
169 iailab:
170   info:
171     version: 1.0.0
172     base-package: com.iailab.module.system
173   web:
174     admin-ui:
08e3e8 175       url:  # Admin 管理后台 UI 的地址
325d2f 176   xss:
H 177     enable: false
178     exclude-urls: # 如下 url,仅仅是为了演示,去掉配置也没关系
179       - ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求
e7c126 180   swagger:
H 181     title: 管理后台
182     description: 提供管理员管理的所有功能
183     version: ${iailab.info.version}
184   tenant: # 多租户相关配置项
4a47e4 185     enable: true
e7c126 186     ignore-urls:
H 187       - /admin-api/system/tenant/get-id-by-name # 基于名字获取租户,不许带租户编号
188       - /admin-api/system/tenant/get-by-website # 基于域名获取租户,不许带租户编号
189       - /admin-api/system/captcha/get-image # 获取图片验证码,和租户无关
190       - /admin-api/system/captcha/get # 获取图片验证码,和租户无关
191       - /admin-api/system/captcha/check # 校验图片验证码,和租户无关
192       - /admin-api/system/sms/callback/* # 短信回调接口,无法带上租户编号
193       - /rpc-api/system/tenant/valid # 防止递归。避免调用 /rpc-api/system/tenant/valid 接口时,又去触发 /rpc-api/system/tenant/valid 去校验
194       - /rpc-api/system/tenant/id-list # 获得租户列表的时候,无需传递租户编号
195       - /rpc-api/system/oauth2/token/check # 访问令牌校验时,无需传递租户编号;主要解决上传文件的场景,前端不会传递 tenant-id!
4a47e4 196     ignore-caches:
H 197       - permission_menu_ids
198       - oauth_client
199       - notify_template
200       - mail_account
201       - mail_template
202       - sms_template
e7c126 203     ignore-tables:
1c5a2c 204       - system_app
ce910c 205       - system_app_group
e7c126 206       - system_tenant
H 207       - system_tenant_package
208       - system_dict_data
209       - system_dict_type
210       - system_error_code
211       - system_menu
212       - system_sms_channel
213       - system_sms_template
214       - system_sms_log
215       - system_sensitive_word
216       - system_oauth2_client
217       - system_mail_account
218       - system_mail_template
219       - system_mail_log
220       - system_notify_template
221   sms-code: # 短信验证码相关的配置项
222     expire-times: 10m
223     send-frequency: 1m
224     send-maximum-quantity-per-day: 10
225     begin-code: 9999 # 这里配置 9999 的原因是,测试方便。
226     end-code: 9999 # 这里配置 9999 的原因是,测试方便。
227
228 debug: false