application.yaml 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. spring:
  2. application:
  3. name: bpm-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. # liquibase:
  32. # parameters:
  33. # skipDatabaseStep: true
  34. server:
  35. port: 48083
  36. logging:
  37. file:
  38. name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径
  39. level:
  40. org.flowable: DEBUG
  41. liquibase: DEBUG
  42. org.springframework.jdbc: TRACE
  43. --- #################### 接口文档配置 ####################
  44. springdoc:
  45. api-docs:
  46. enabled: true # 1. 是否开启 Swagger 接文档的元数据
  47. path: /v3/api-docs
  48. swagger-ui:
  49. enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面
  50. path: /swagger-ui
  51. default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档
  52. knife4j:
  53. enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面
  54. setting:
  55. language: zh_cn
  56. # 工作流 Flowable 配置
  57. flowable:
  58. # 1. false: 默认值,Flowable 启动时,对比数据库表中保存的版本,如果不匹配。将抛出异常
  59. # 2. true: 启动时会对数据库中所有表进行更新操作,如果表存在,不做处理,反之,自动创建表
  60. # 3. create_drop: 启动时自动创建表,关闭时自动删除表
  61. # 4. drop_create: 启动时,删除旧表,再创建新表
  62. database-schema-update: drop_create # 设置为 false,可通过 https://github.com/flowable/flowable-sql 初始化
  63. db-history-used: true # flowable6 默认 true 生成信息表,无需手动设置
  64. check-process-definitions: false # 设置为 false,禁用 /resources/processes 自动部署 BPMN XML 流程
  65. history-level: audit # full:保存历史数据的最高级别,可保存全部流程相关细节,包括流程流转各节点参数
  66. # ignore-duplicate-tables: true
  67. # drop-first: false
  68. # MyBatis Plus 的配置项
  69. mybatis-plus:
  70. configuration:
  71. map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。
  72. global-config:
  73. db-config:
  74. id-type: NONE # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。
  75. # id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库
  76. # id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库
  77. # id-type: ASSIGN_ID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解
  78. logic-delete-value: 1 # 逻辑已删除值(默认为 1)
  79. logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
  80. banner: false # 关闭控制台的 Banner 打印
  81. type-aliases-package: ${tz.info.base-package}.dal.dataobject
  82. encryptor:
  83. password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成
  84. mybatis-plus-join:
  85. banner: false # 关闭控制台的 Banner 打印
  86. # Spring Data Redis 配置
  87. spring:
  88. data:
  89. redis:
  90. repositories:
  91. enabled: false # 项目未使用到 Spring Data Redis 的 Repository,所以直接禁用,保证启动速度
  92. # VO 转换(数据翻译)相关
  93. easy-trans:
  94. is-enable-global: true # 启用全局翻译(拦截所有 SpringMVC ResponseBody 进行自动翻译 )。如果对于性能要求很高可关闭此配置,或通过 @IgnoreTrans 忽略某个接口
  95. --- #################### RPC 远程调用相关配置 ####################
  96. --- #################### MQ 消息队列相关配置 ####################
  97. --- #################### 定时任务相关配置 ####################
  98. xxl:
  99. job:
  100. executor:
  101. appname: ${spring.application.name} # 执行器 AppName
  102. logpath: ${user.home}/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径
  103. accessToken: default_token # 执行器通讯TOKEN
  104. --- #################### 芋道相关配置 ####################
  105. tz:
  106. info:
  107. version: 1.0.0
  108. base-package: cn.start.tz.module.bpm
  109. web:
  110. admin-ui:
  111. url: http://dashboard.tz.iocoder.cn # Admin 管理后台 UI 的地址
  112. xss:
  113. enable: false
  114. exclude-urls: # 如下 url,仅仅是为了演示,去掉配置也没关系
  115. - ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求
  116. swagger:
  117. title: 管理后台
  118. description: 提供管理员管理的所有功能
  119. version: ${tz.info.version}
  120. tenant: # 多租户相关配置项
  121. enable: false
  122. debug: false