application.yaml 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. spring:
  2. application:
  3. name: infra-server
  4. profiles:
  5. active: local
  6. main:
  7. allow-circular-references: true # 允许循环依赖,因为项目是三层架构,无法避免这个情况。
  8. allow-bean-definition-overriding: true # 允许 Bean 覆盖,例如说 Feign 等会存在重复定义的服务
  9. config:
  10. import:
  11. - optional:classpath:application-${spring.profiles.active}.yaml # 加载【本地】配置
  12. - optional:nacos:${spring.application.name}-${spring.profiles.active}.yaml # 加载【Nacos】的配置
  13. # Servlet 配置
  14. servlet:
  15. # 文件上传相关配置项
  16. multipart:
  17. max-file-size: 16MB # 单个文件大小
  18. max-request-size: 32MB # 设置总上传的文件大小
  19. # Jackson 配置项
  20. jackson:
  21. serialization:
  22. write-dates-as-timestamps: true # 设置 LocalDateTime 的格式,使用时间戳
  23. write-date-timestamps-as-nanoseconds: false # 设置不使用 nanoseconds 的格式。例如说 1611460870.401,而是直接 1611460870401
  24. write-durations-as-timestamps: true # 设置 Duration 的格式,使用时间戳
  25. fail-on-empty-beans: false # 允许序列化无属性的 Bean
  26. # Cache 配置项
  27. cache:
  28. type: REDIS
  29. redis:
  30. time-to-live: 1h # 设置过期时间为 1 小时
  31. server:
  32. port: 48082
  33. logging:
  34. file:
  35. name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径
  36. --- #################### 接口文档配置 ####################
  37. springdoc:
  38. api-docs:
  39. enabled: true # 1. 是否开启 Swagger 接文档的元数据
  40. path: /v3/api-docs
  41. swagger-ui:
  42. enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面
  43. path: /swagger-ui
  44. default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档
  45. knife4j:
  46. enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面
  47. setting:
  48. language: zh_cn
  49. # MyBatis Plus 的配置项
  50. mybatis-plus:
  51. configuration:
  52. map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。
  53. global-config:
  54. db-config:
  55. # id-type: NONE # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。
  56. # id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库
  57. # id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库
  58. id-type: ASSIGN_UUID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解
  59. logic-delete-value: 1 # 逻辑已删除值(默认为 1)
  60. logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
  61. banner: false # 关闭控制台的 Banner 打印
  62. type-aliases-package: ${tz.info.base-package}.dal.dataobject
  63. encryptor:
  64. password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成
  65. mybatis-plus-join:
  66. banner: false # 关闭控制台的 Banner 打印
  67. # Spring Data Redis 配置
  68. spring:
  69. data:
  70. redis:
  71. repositories:
  72. enabled: false # 项目未使用到 Spring Data Redis 的 Repository,所以直接禁用,保证启动速度
  73. # VO 转换(数据翻译)相关
  74. easy-trans:
  75. is-enable-global: true # 启用全局翻译(拦截所有 SpringMVC ResponseBody 进行自动翻译 )。如果对于性能要求很高可关闭此配置,或通过 @IgnoreTrans 忽略某个接口
  76. --- #################### RPC 远程调用相关配置 ####################
  77. --- #################### 消息队列相关 ####################
  78. # rocketmq 配置项,对应 RocketMQProperties 配置类
  79. rocketmq:
  80. # Producer 配置项
  81. producer:
  82. group: ${spring.application.name}_PRODUCER # 生产者分组
  83. spring:
  84. # Kafka 配置项,对应 KafkaProperties 配置类
  85. kafka:
  86. # Kafka Producer 配置项
  87. producer:
  88. acks: 1 # 0-不应答。1-leader 应答。all-所有 leader 和 follower 应答。
  89. retries: 3 # 发送失败时,重试发送的次数
  90. value-serializer: org.springframework.kafka.support.serializer.JsonSerializer # 消息的 value 的序列化
  91. # Kafka Consumer 配置项
  92. consumer:
  93. auto-offset-reset: earliest # 设置消费者分组最初的消费进度为 earliest 。可参考博客 https://blog.csdn.net/lishuangzhe7047/article/details/74530417 理解
  94. value-deserializer: org.springframework.kafka.support.serializer.JsonDeserializer
  95. properties:
  96. spring.json.trusted.packages: '*'
  97. # Kafka Consumer Listener 监听器配置
  98. listener:
  99. missing-topics-fatal: false # 消费监听接口监听的主题不存在时,默认会报错。所以通过设置为 false ,解决报错
  100. --- #################### 定时任务相关配置 ####################
  101. xxl:
  102. job:
  103. executor:
  104. appname: ${spring.application.name} # 执行器 AppName
  105. logpath: ${user.home}/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径
  106. accessToken: default_token # 执行器通讯TOKEN
  107. --- #################### 芋道相关配置 ####################
  108. tz:
  109. info:
  110. version: 1.0.0
  111. base-package: cn.start.tz.module.infra
  112. web:
  113. admin-ui:
  114. url: http://dashboard.tz.iocoder.cn # Admin 管理后台 UI 的地址
  115. xss:
  116. enable: false
  117. exclude-urls: # 如下两个 url,仅仅是为了演示,去掉配置也没关系
  118. - ${spring.boot.admin.context-path}/** # 不处理 Spring Boot Admin 的请求
  119. - ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求
  120. websocket:
  121. enable: true # websocket的开关
  122. path: /infra/ws # 路径
  123. sender-type: local # 消息发送的类型,可选值为 local、redis、rocketmq、kafka、rabbitmq
  124. sender-rocketmq:
  125. topic: ${spring.application.name}-websocket # 消息发送的 RocketMQ Topic
  126. consumer-group: ${spring.application.name}-websocket-consumer # 消息发送的 RocketMQ Consumer Group
  127. sender-rabbitmq:
  128. exchange: ${spring.application.name}-websocket-exchange # 消息发送的 RabbitMQ Exchange
  129. queue: ${spring.application.name}-websocket-queue # 消息发送的 RabbitMQ Queue
  130. sender-kafka:
  131. topic: ${spring.application.name}-websocket # 消息发送的 Kafka Topic
  132. consumer-group: ${spring.application.name}-websocket-consumer # 消息发送的 Kafka Consumer Group
  133. swagger:
  134. title: 管理后台
  135. description: 提供管理员管理的所有功能
  136. version: ${tz.info.version}
  137. codegen:
  138. base-package: cn.start.tz
  139. db-schemas: ${spring.datasource.dynamic.datasource.master.name}
  140. front-type: 20 # 前端模版的类型,参见 CodegenFrontTypeEnum 枚举类
  141. unit-test-enable: false # 是否生成单元测试
  142. tenant: # 多租户相关配置项
  143. enable: false
  144. ignore-urls:
  145. - /admin-api/infra/file/*/get/** # 获取图片,和租户无关
  146. ignore-tables:
  147. - infra_codegen_column
  148. - infra_codegen_table
  149. - infra_config
  150. - infra_file_config
  151. - infra_file
  152. - infra_file_content
  153. - infra_job
  154. - infra_job_log
  155. - infra_job_log
  156. - infra_data_source_config
  157. debug: false