springboot配置文件很强大、也丰富,“约定优于配置”,只需做少量的配置,其它采用默认的就行。
application.properties(传统),application.yml(重点)
服务器端口配置
server:
port: 8080 # 端口号
日志配置
#debug: true
# 设置日志级别,root表示根节点,即整体应用日志级别
logging:
level:
root: info #root级别
#日志级别从低到高:TRACE < DEBUG < INFO(开发) < WARN(生产系统上线时) < ERROR(生产系统上线时)< FATAL
com.jcj.mydemo: warn # package级别
#Spring Boot默认使用LogBack日志系统,日志默认输出到控制台的
file: # 日志输入一个固定的地方,存在文件里
name: logs/system.log # 将日志存在logs下的system.log日志中
JPA配置
spring:
jpa:
#放入公共部分
#注意:数据库要预先建立好,因为hibernate只会建表,不会建库
#update:表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列。
#create:启动hibernate时,自动删除原来的表,新建所有的表,所以每次启动后的以前数据都会丢失。
#create-drop:启动hibernate时,自动创建表,程序关闭时,自动把相应的表都删除。所以程序结束时,表和数据也不会再存在。
hibernate:
ddl-auto: update # 有三个选项:update、create、create-drop
show-sql: true # 表示项目运行时要不要输出sql语句
数据库连接池配置
自Druid1.1.10版本以后,完全基于yml就能让Druid运行起来
要做的工作:
1)pom.xml增加jpa、Mysql、Druid的jar包依赖
<!--Mysql驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.28</version>
<scope>runtime</scope>
</dependency>
<!--Druid数据库连接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.10</version>
</dependency>
<!--JPA-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
2)在配置文件中增加配置参数
spring:
# 数据源
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver # 驱动(pom.xml中已经引入了Mysql依赖)
url: jdbc:mysql://127.0.0.1:3306/goodswarndb?serverTimezone=UTC&useSSL=false #serverTimezone=UTC指定时区,表示全球标准时间 useSSL=false表示普通连接
username: root
password: 123456
#Druid数据源配置
type: com.alibaba.druid.pool.DruidDataSource
druid:
initial-size: 5 #初始化时建立物理连接的个数
min-idle: 5 #最小连接池数量
maxActive: 20 #最大连接池数量
maxWait: 60000 #获取连接时最大等待时间,单位毫秒
timeBetweenEvictionRunsMillis: 60000 #配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
minEvictableIdleTimeMillis: 300000 #配置一个连接在池中最小生存的时间,单位是毫秒
validationQuery: SELECT 1 #用来检测连接是否有效的sql
testWhileIdle: true #申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效
testOnBorrow: false #申请连接时执行validationQuery检测连接是否有效,如果为true会降低性能
testOnReturn: false #归还连接时执行validationQuery检测连接是否有效,如果为true会降低性能
poolPreparedStatements: true # 打开PSCache,并且指定每个连接上PSCache的大小
maxPoolPreparedStatementPerConnectionSize: 20 #要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100
filters: stat,wall,slf4j #配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
#通过connectProperties属性来打开mergeSql功能;慢SQL记录
connectionProperties: druid.stat.mergeSql\=true;druid.stat.slowSqlMillis\=5000
# 配置DruidStatFilter,用于采集web-jdbc关联监控的数据
web-stat-filter:
enabled: true
url-pattern: "/*"
#排除一些不必要的url过滤
exclusions: "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*"
# 配置DruidStatViewServlet
stat-view-servlet:
url-pattern: "/druid/*" # 约定的格式
# IP白名单(没有配置或者为空,则只能在本地访问)
allow: 127.0.0.1,192.168.31.76
# IP黑名单 (存在共同时,deny优先于allow)
deny: 192.168.1.73
# 禁用HTML页面上的“Reset All”功能
reset-enable: false
# 可视化界面,登录名
login-username: admin
# 可视化界面,登录密码
login-password: admin123456
环境激活
设:有application-dev.yml、application.yml-pro、application.yml
# application.yml内容
spring:
profiles:
active: dev
thymeleaf配置
一般情况下,无需在yml中进行配置,采用其默认配置就很好,thymeleaf的默认配置如下:
spring.thymeleaf.cache #是否开启模板缓存,默认true
spring.thymeleaf.check-template-location #是否检查模板路径是否存在,默认true
spring.thymeleaf.content-type #指定Content-Type,默认为: text/html
spring.thymeleaf.enabled #是否允许MVC使用Thymeleaf,默认为: true
spring.thymeleaf.encoding #指定模板的编码,默认为: UTF-8
spring.thymeleaf.excluded-view-names #指定不使用模板的视图名称,多个以逗号分隔.
spring.thymeleaf.mode #指定模板的模式,具体查看StandardTemplateModeHandlers,默认为: HTML5
spring.thymeleaf.prefix #指定模板的前缀,默认为:classpath:/templates/
spring.thymeleaf.suffix #指定模板的后缀,默认为:.html
spring.thymeleaf.template-resolver-order #指定模板的解析顺序,默认为第一个.
spring.thymeleaf.view-names #指定使用模板的视图名,多个以逗号分隔.
resource配置
Resource是指资源相关的配置,一般情况下,无需在yml中进行配置,采用其默认配置就很好,默认配置如下:
spring.resources.add-mappings #是否开启默认的资源处理,默认为true
spring.resources.cache-period #设定资源的缓存时效,以秒为单位.
spring.resources.chain.cache #是否开启缓存,默认为: true
spring.resources.chain.enabled #是否开启资源 handling chain,默认为false
spring.resources.chain.html-application-cache #是否开启h5应用的cache manifest重写,默认为: false
spring.resources.chain.strategy.content.enabled #是否开启内容版本策略,默认为false
spring.resources.chain.strategy.content.paths #指定要应用的版本的路径,多个以逗号分隔,默认为:[/**]
spring.resources.chain.strategy.fixed.enabled #是否开启固定的版本策略,默认为false
spring.resources.chain.strategy.fixed.paths #指定要应用版本策略的路径,多个以逗号分隔
spring.resources.chain.strategy.fixed.version #指定版本策略使用的版本号
spring.resources.static-locations #指定静态资源路径,默认为classpath:[/META-INF/resources/,/resources/, /static/, /public/]以及context:/