dengzedong
2024-12-24 aa0382e44311f9f7e62a688c8fcaa9c69a512e0f
提交 | 用户 | 时间
e7c126 1 spring:
d9f9ba 2   application:
H 3     name: infra-server
4
5   profiles:
4a47e4 6     active: @profiles.active@
H 7
8   cloud:
9     nacos:
10       server-addr: @nacos.server@ # Nacos 服务器地址
11       username: @nacos.username@
12       password: @nacos.password@
13       discovery: # 【配置中心】配置项
49b4b6 14 #        ip: @deploy.server@
4a47e4 15         namespace: @profiles.active@
H 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: 48082
58
59 logging:
60   file:
49b4b6 61     name: @log.path@/iailab-infra/log/${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
72   default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档
73
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: NONE # “智能”模式,基于 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
110 --- #################### RPC 远程调用相关配置 ####################
111
112 --- #################### 消息队列相关 ####################
113
114 # rocketmq 配置项,对应 RocketMQProperties 配置类
115 rocketmq:
116   # Producer 配置项
117   producer:
118     group: ${spring.application.name}_PRODUCER # 生产者分组
119
120 spring:
121   # Kafka 配置项,对应 KafkaProperties 配置类
122   kafka:
123     # Kafka Producer 配置项
124     producer:
125       acks: 1 # 0-不应答。1-leader 应答。all-所有 leader 和 follower 应答。
126       retries: 3 # 发送失败时,重试发送的次数
127       value-serializer: org.springframework.kafka.support.serializer.JsonSerializer # 消息的 value 的序列化
128     # Kafka Consumer 配置项
129     consumer:
130       auto-offset-reset: earliest # 设置消费者分组最初的消费进度为 earliest 。可参考博客 https://blog.csdn.net/lishuangzhe7047/article/details/74530417 理解
131       value-deserializer: org.springframework.kafka.support.serializer.JsonDeserializer
132       properties:
133         spring.json.trusted.packages: '*'
134     # Kafka Consumer Listener 监听器配置
135     listener:
136       missing-topics-fatal: false # 消费监听接口监听的主题不存在时,默认会报错。所以通过设置为 false ,解决报错
137
138 --- #################### 定时任务相关配置 ####################
139
140 xxl:
141   job:
142     executor:
143       appname: ${spring.application.name} # 执行器 AppName
21dc7e 144       logpath: D:/DLUT/IailabPlat/webapp/infra/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径
e7c126 145     accessToken: default_token # 执行器通讯TOKEN
H 146
147 --- #################### 平台相关配置 ####################
148
149 iailab:
150   info:
151     version: 1.0.0
152     base-package: com.iailab.module.infra
153   web:
154     admin-ui:
08e3e8 155       url:  # Admin 管理后台 UI 的地址
325d2f 156   xss:
H 157     enable: false
158     exclude-urls: # 如下两个 url,仅仅是为了演示,去掉配置也没关系
159       - ${spring.boot.admin.context-path}/** # 不处理 Spring Boot Admin 的请求
160       - ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求
e7c126 161   websocket:
H 162     enable: true # websocket的开关
163     path: /infra/ws # 路径
21dc7e 164     sender-type: rabbitmq # 消息发送的类型,可选值为 local、redis、rocketmq、kafka、rabbitmq
e7c126 165     sender-rocketmq:
H 166       topic: ${spring.application.name}-websocket # 消息发送的 RocketMQ Topic
167       consumer-group: ${spring.application.name}-websocket-consumer # 消息发送的 RocketMQ Consumer Group
168     sender-rabbitmq:
169       exchange: ${spring.application.name}-websocket-exchange # 消息发送的 RabbitMQ Exchange
170       queue: ${spring.application.name}-websocket-queue # 消息发送的 RabbitMQ Queue
171     sender-kafka:
172       topic: ${spring.application.name}-websocket # 消息发送的 Kafka Topic
173       consumer-group: ${spring.application.name}-websocket-consumer # 消息发送的 Kafka Consumer Group
174   swagger:
175     title: 管理后台
176     description: 提供管理员管理的所有功能
177     version: ${iailab.info.version}
178   codegen:
179     base-package: com.iailab
180     db-schemas: ${spring.datasource.dynamic.datasource.master.name}
181     front-type: 10 # 前端模版的类型,参见 CodegenFrontTypeEnum 枚举类
182   tenant: # 多租户相关配置项
183     enable: true
184     ignore-urls:
185       - /admin-api/infra/file/*/get/** # 获取图片,和租户无关
186     ignore-tables:
187       - infra_codegen_column
188       - infra_codegen_table
189       - infra_config
190       - infra_file_config
191       - infra_file
192       - infra_file_content
193       - infra_job
194       - infra_job_log
195       - infra_job_log
196       - infra_data_source_config
197
198 debug: false