application-local.yaml 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. --- #################### 注册中心 + 配置中心相关配置 ####################
  2. spring:
  3. cloud:
  4. nacos:
  5. discovery:
  6. enabled: false # 禁用 Nacos 服务发现,本地开发不需要 Nacos
  7. config:
  8. enabled: false # 禁用 Nacos 配置中心,本地开发不需要 Nacos
  9. import-check:
  10. enabled: false # 禁用 Nacos 配置检查,本地开发不需要 Nacos
  11. openfeign:
  12. enabled: true # 启用 Feign 客户端
  13. client:
  14. config:
  15. # OAuth2TokenCommonApi 通过 Feign 调用用户服务(因为 Token 表在用户服务)
  16. # 注意:OAuth2TokenCommonApi 的 @FeignClient 使用的是 RpcConstants.SYSTEM_NAME
  17. # 但我们需要让它指向用户服务,所以需要在配置中指定
  18. system-server: # 将 system-server 映射到用户服务地址
  19. url: http://localhost:18080
  20. user-server:
  21. url: http://localhost:18080 # 本地开发时,直接指定用户服务地址
  22. xdz-user-server: # 会员管理相关的 Feign 客户端使用 xdz-user-server
  23. url: http://localhost:18080 # 本地开发时,直接指定用户服务地址
  24. xdz-vehicle-server: # 车辆服务(无 context-path)
  25. url: http://localhost:18083 # 本地开发时,直接指定车辆服务地址
  26. xdz-message-server: # 消息服务(无 context-path)
  27. url: http://localhost:18082 # 本地开发时,直接指定消息服务地址
  28. default-to-properties: false # 禁用默认配置,使用自定义配置
  29. --- #################### 服务间 JWT 配置 ####################
  30. xdz:
  31. security:
  32. service-jwt:
  33. enabled: true # 启用服务间 JWT 验证
  34. private-key-path: classpath:jwt/service_jwt_private_key.pem # 私钥路径(用于生成 Token)
  35. public-key-path: classpath:jwt/service_jwt_public_key.pem # 公钥路径(用于验证 Token)
  36. expire-time: 3600 # Token 过期时间(秒),默认 1 小时
  37. --- #################### 数据库相关配置 ####################
  38. spring:
  39. # 数据源配置项
  40. autoconfigure:
  41. exclude:
  42. - com.xindazhou.framework.apilog.config.XdzApiLogRpcAutoConfiguration # 禁用 Feign 客户端自动配置,使用本地实现
  43. # 禁用 XdzSecurityRpcAutoConfiguration,避免 OAuth2TokenCommonApi 的 Feign 客户端与本地实现冲突
  44. # LoginUserRequestInterceptor 已在 RpcConfiguration 中手动注册
  45. - com.xindazhou.framework.security.config.XdzSecurityRpcAutoConfiguration
  46. datasource:
  47. druid: # Druid 【监控】相关的全局配置
  48. web-stat-filter:
  49. enabled: true
  50. stat-view-servlet:
  51. enabled: true
  52. allow: # 设置白名单,不填则允许所有访问
  53. url-pattern: /druid/*
  54. login-username: # 控制台管理用户名和密码
  55. login-password:
  56. filter:
  57. stat:
  58. enabled: true
  59. log-slow-sql: true # 慢 SQL 记录
  60. slow-sql-millis: 100
  61. merge-sql: true
  62. wall:
  63. config:
  64. multi-statement-allow: true
  65. dynamic: # 多数据源配置
  66. druid: # Druid 【连接池】相关的全局配置
  67. initial-size: 1 # 初始连接数
  68. min-idle: 1 # 最小连接池数量
  69. max-active: 20 # 最大连接池数量
  70. max-wait: 60000 # 配置获取连接等待超时的时间,单位:毫秒(1 分钟)
  71. time-between-eviction-runs-millis: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位:毫秒(1 分钟)
  72. min-evictable-idle-time-millis: 600000 # 配置一个连接在池中最小生存的时间,单位:毫秒(10 分钟)
  73. max-evictable-idle-time-millis: 1800000 # 配置一个连接在池中最大生存的时间,单位:毫秒(30 分钟)
  74. validation-query: SELECT 1 FROM DUAL # 配置检测连接是否有效
  75. test-while-idle: true
  76. test-on-borrow: false
  77. test-on-return: false
  78. pool-prepared-statements: true # 是否开启 PreparedStatement 缓存
  79. max-pool-prepared-statement-per-connection-size: 20 # 每个连接缓存的 PreparedStatement 数量
  80. primary: master
  81. datasource:
  82. master:
  83. url: jdbc:mysql://119.45.95.228:10022/xdz_business?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true&rewriteBatchedStatements=true&useUnicode=true&characterEncoding=UTF-8
  84. username: root
  85. password: xdz@123!
  86. # 社区模块数据源(社区表也在xdz_business数据库中,使用同一个数据源)
  87. slave: # 模拟从库,可根据自己需要修改
  88. lazy: true # 开启懒加载,保证启动速度
  89. url: jdbc:mysql://119.45.95.228:10022/xdz_business?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true&rewriteBatchedStatements=true&useUnicode=true&characterEncoding=UTF-8
  90. username: root
  91. password: xdz@123!
  92. # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优
  93. data:
  94. redis:
  95. host: 119.45.95.228 # 地址
  96. port: 10011 # 端口
  97. database: 0 # 数据库索引
  98. password: xdz123@Q
  99. --- #################### MQ 消息队列相关配置 ####################
  100. # rocketmq 配置项,对应 RocketMQProperties 配置类
  101. rocketmq:
  102. name-server: 127.0.0.1:9876 # RocketMQ Namesrv
  103. spring:
  104. # RabbitMQ 配置项,对应 RabbitProperties 配置类
  105. rabbitmq:
  106. host: 127.0.0.1 # RabbitMQ 服务的地址
  107. port: 5672 # RabbitMQ 服务的端口
  108. username: guest # RabbitMQ 服务的账号
  109. password: guest # RabbitMQ 服务的密码
  110. # Kafka 配置项,对应 KafkaProperties 配置类
  111. kafka:
  112. bootstrap-servers: 127.0.0.1:9092 # 指定 Kafka Broker 地址,可以设置多个,以逗号分隔
  113. --- #################### 定时任务相关配置 ####################
  114. xxl:
  115. job:
  116. enabled: false # 是否开启调度中心,默认为 true 开启
  117. admin:
  118. addresses: http://127.0.0.1:9090/xxl-job-admin # 调度中心部署跟地址
  119. --- #################### 服务保障相关配置 ####################
  120. # Lock4j 配置项
  121. lock4j:
  122. acquire-timeout: 3000 # 获取分布式锁超时时间,默认为 3000 毫秒
  123. expire: 30000 # 分布式锁的超时时间,默认为 30 毫秒
  124. --- #################### 监控相关配置 ####################
  125. # Actuator 监控端点的配置项
  126. management:
  127. endpoints:
  128. web:
  129. base-path: /actuator # Actuator 提供的 API 接口的根目录。默认为 /actuator
  130. exposure:
  131. include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。
  132. # Spring Boot Admin 配置项
  133. spring:
  134. boot:
  135. admin:
  136. # Spring Boot Admin Client 客户端的相关配置
  137. client:
  138. instance:
  139. service-host-type: IP # 注册实例时,优先使用 IP [IP, HOST_NAME, CANONICAL_HOST_NAME]
  140. username: admin
  141. password: admin
  142. # Spring Boot Admin Server 服务端的相关配置
  143. context-path: /admin # 配置 Spring
  144. # 日志文件配置
  145. logging:
  146. level:
  147. # 配置自己写的 MyBatis Mapper 打印日志
  148. com.xindazhou.business.dal.mysql: DEBUG
  149. com.xindazhou.business.dal.mysql.logger.ApiErrorLogMapper: INFO # 配置 ApiErrorLogMapper 的日志级别为 info,避免和 GlobalExceptionHandler 重复打印
  150. com.xindazhou.business.dal.mysql.file.FileConfigMapper: INFO # 配置 FileConfigMapper 的日志级别为 info
  151. org.springframework.context.support.PostProcessorRegistrationDelegate: ERROR # ,Spring Boot 3.X 存在部分错误的 WARN 提示
  152. --- #################### xdz相关配置 ####################
  153. # 新大洲配置项,设置当前项目所有自定义的配置
  154. xdz:
  155. env: # 多环境的配置项
  156. tag: ${HOSTNAME}
  157. security:
  158. mock-enable: true
  159. oauth2-jwt:
  160. enabled: true # 启用 OAuth2 JWT Token 验证(统一使用 JWT 格式)
  161. public-key-path: classpath:jwt/oauth2_jwt_public_key.pem # 公钥路径(用于验证 Token,业务服务不需要私钥)
  162. access-log: # 访问日志的配置项
  163. enable: true # 启用 API 访问日志(使用本地服务,不通过 Feign)
  164. tenant: # 多租户相关配置项
  165. enable: false # 本地开发暂时禁用多租户
  166. ignore-urls: # 需要忽略多租户的请求(即使启用多租户,这些 URL 也不需要传递 tenant-id)
  167. - /admin-api/system/auth/login # 登录接口
  168. - /admin-api/system/auth/logout # 登出接口
  169. - /admin-api/system/auth/refresh-token # 刷新令牌接口
  170. - /admin-api/system/auth/get-permission-info # 获取权限信息接口
  171. websocket:
  172. enable: true # websocket的开关
  173. path: /business/ws # 路径
  174. sender-type: local # 消息发送的类型,可选值为 local、redis、rocketmq、kafka、rabbitmq
  175. --- #################### 微信相关配置 ####################
  176. # 微信配置(如果不需要可以留空,但需要配置 appid 和 secret 避免启动错误)
  177. wx:
  178. mp:
  179. config-storage:
  180. type: memory
  181. app-id: "dummy-appid" # 临时配置,避免启动错误
  182. secret: "dummy-secret" # 临时配置,避免启动错误