SpringBoot学习笔记(三)——Springboot配置文件
SpringBoot不像之前用spring+springMVC做项目的时候,他不需要配置大量的看上去很乱很复杂的xml配置文件。在SpringBoot中你可以通过java代码和注解配置项目,也可以通过简单的几个配置文件来配置项目。
这篇学习笔记只记录下配置文件的使用,至于用java代码配置的内容下次再写。
SpringBoot配置文件
spring的配置文件有两种格式:
1、application.properties
2、application.yml
这两种文件可以选择一种来当作你项目的配置文件,但是官方推荐使用yml来配置,因为他的语法看起来更简洁和清晰,接下来我也会使用这个格式来做例子。
SpringBoot这两种配置文件写法的不同
这两种配置文件本质上是一样的,只是语法(表现形式)不同,用两个很简单的例子就可以看出".properties"格式和".yml"这两种配置文件语法的不同。
1、配置服务的端口号
application.properties文件这样写
server.port=9014
application.yml文件这样写
server: port: 8889
2、配置数据库驱动类型
application.properties文件这样写
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
application.yml文件这样写(当然这里直接配置了数据库连接池使用的是druid)
spring: datasource: druid: driver-class-name: com.mysql.jdbc.Driver
上面的例子可以轻易的看出来他们的区别,yml格式的一般就是把properties的点,换成了下一行加“空格”。
所有一般会一种另一种也就会了,这里推荐使用yml格式的(看着很清爽有没有,没有啥重复的多余的代码,而且层级关系显示的很明显)。
SpringBoot配置文件application.yml格式注意点
这个格式其实没有多少语法,一般用几次,看几个例子也就会用了,但是要配置复杂的还是要研究下的。
这是我整理了几个注意点:
1、用键: 值的方式表现属性和配置的。(这里注意,“:”符号有后面一定要跟一个空格)
2、使用“缩进”的方式表现层级关系。缩进了几个空格没事,但是同一层级的右边要对其。就像下面的。
3、大小写敏感。
datasource: type: com.alibaba.druid.pool.DruidDataSource druid: driver-class-name: com.mysql.jdbc.Driver username: root password: 1111111
更多详细yml语法我找到个大神的文章,给个传送门:(传送门)
官方的参考:(http://www.yaml.org)
SpringBoot配置文件的加载
springboot的配置文件的加载是有优先级和顺序的,springboot启动的时候会默认加载一些位置的配置文件。了解一下看别人项目的时候就可以轻易的找到配置文件啦。
一、加载顺序
SpringBoot启动的时候会扫描加载下面几个位置的application.properties/application.yml文件:
1、./config——根目录(项目目录)下的一个config文件夹
2、./——根目录下面
3、classpath:/config——classpath路径下的config文件夹。这个classpath路径这里一般指的是src/main/resources/config,最好不要跟代码放一块。
4、classpath/——这个就是classpath路径了,一般就是src/main/resources。
二、加载配置的优先级
1、上面加载配置是由大到小的优先级。
2、同一目录下的文件:.properties > .yml。(还是properties优先级高点,但我还是用yml)
3、先加载的配置就会应用哪个配置,不会被后加载的覆盖。
参考大佬:(传送门)
一些常用的配置例子
更新中。。。。。。。。。。。
服务配置
server: #配置端口号 port: 8174 #配置tomcat tomcat: #配置tomcat的URI编码 uri-encoding: UTF-8 # tomcat的最大线程数,默认值为200 max-threads: 100
数据库配置
#spring相关配置 spring: #配置数据源 datasource: name: ds #配置alibaba的Drui数据库连接池,也可以换成别的,但是要别的依赖 type: com.alibaba.druid.pool.DruidDataSource #配置数据库驱动 driver-class-name: com.mysql.cj.jdbc.Driver #druid配置 druid: #数据库基本属性 url: jdbc:mysql://localhost:3306/test1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 username: root password: 123456 #初始化的时候建立的连接数,默认为0 initial-size: 1 #最大链接数量 max-active: 8 #最小连接池数量 min-idle: 1 #获取连接等待超时时间 max-wait: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 timeBetweenEvictionRunsMillis: 60000 # 配置一个连接在池中最小生存的时间,单位是毫秒 minEvictableIdleTimeMillis: 300000 # 配置一个连接在池中最大生存的时间,单位是毫秒 maxEvictableIdleTimeMillis: 900000 # 检测配置是不是链接有效 validationQuery: SELECT 1 FROM DUAL
thymeleaf配置
spring: #配置Thymeleaf模板 thymeleaf: #模板模式 mode: HTML #启用模板缓存,一般开发环境会把值设置为false,正式环境设置为true cache: false #模板的编码 encoding: UTF-8 #增加视图解析时候的前缀和后缀名,比如返回一个index,就自动组成:classpath:/templates/index.html prefix: classpath:/templates/ suffix: .html
分页插件PageHelper配置
#配置分页插件pagehelper pagehelper: #配置使用的数据库方言 helper-dialect: mysql reasonable: true support-methods-arguments: true params: count=countSql retrunPageInfo: check
配置mybatis
#配置mybatis mybatis: #配置扫描xxxMapper.xml配置文件的目录 mapper-locations: classpath:/mapper/*.xml #配置扫描指定的包中的类配置别名。 type-aliases-package: com.*.domain #加载其他的mybatis配置文件 config-location: classpath:mybatis/mybatis-config.xml
如果有哪里写的有问题,欢迎指出来,有啥大神的相关文章欢迎在评论区贴出(传送门)哦。
下面会写一些SpringBoot的java配置笔记。
SpringBoot学习笔记(三)——Springboot配置文件的更多相关文章
- SpringBoot学习笔记:读取配置文件
SpringBoot学习笔记:读取配置文件 配置文件 在以往的项目中,我们主要通过XML文件进行框架配置,业务的相关配置会放在属性文件中,然后通过一个属性读取的工具类来读取配置信息.在SpringBo ...
- SpringBoot学习笔记(6)----SpringBoot中使用Servlet,Filter,Listener的三种方式
在一般的运用开发中Controller已经大部分都能够实现了,但是也不排除需要自己实现Servlet,Filter,Listener的方式,SpringBoot提供了三种实现方式. 1. 使用Bean ...
- springboot学习笔记-6 springboot整合RabbitMQ
一 RabbitMQ的介绍 RabbitMQ是消息中间件的一种,消息中间件即分布式系统中完成消息的发送和接收的基础软件.这些软件有很多,包括ActiveMQ(apache公司的),RocketMQ(阿 ...
- springboot学习笔记:3.配置文件使用概要
Spring Boot允许外化(externalize)你的配置,这样你能够在不同的环境下使用相同的代码. 你可以使用properties文件,YAML文件,环境变量和命令行参数来外化配置.使用@Va ...
- SpringBoot学习笔记三之表述层
注:图片如果损坏,点击文章链接:https://www.toutiao.com/i6803355920697917965/ 首先配置learn-admin-webui中的web.xml文件 配置Con ...
- SpringBoot学习笔记(5)----SpringBoot中异常处理的三种方法
对于异常的处理,Spring Boot中提供默认的一个异常处理界面,如下图: 但是在实际的运用开发中,这样的页面显然是不友好的,Spring Boot也提供了自定义异常处理的方式,如下总结三种一场处理 ...
- SpringBoot学习笔记(6) SpringBoot数据缓存Cache [Guava和Redis实现]
https://blog.csdn.net/a67474506/article/details/52608855 Spring定义了org.springframework.cache.CacheMan ...
- SpringBoot学习笔记(10)-----SpringBoot中使用Redis/Mongodb和缓存Ehcache缓存和redis缓存
1. 使用Redis 在使用redis之前,首先要保证安装或有redis的服务器,接下就是引入redis依赖. pom.xml文件如下 <dependency> <groupId&g ...
- SpringBoot学习笔记(9)----SpringBoot中使用关系型数据库以及事务处理
在实际的运用开发中,跟数据库之间的交互是必不可少的,SpringBoot也提供了两种跟数据库交互的方式. 1. 使用JdbcTemplate 在SpringBoot中提供了JdbcTemplate模板 ...
- springboot学习笔记-5 springboot整合shiro
shiro是一个权限框架,具体的使用可以查看其官网 http://shiro.apache.org/ 它提供了很方便的权限认证和登录的功能. 而springboot作为一个开源框架,必然提供了和sh ...
随机推荐
- CentOS6.5-6.9安装 docker
安装docker yum -y install docker-io 备注:查看内核版本uname -r ;卸载docker版本命令 yum remove docker 更改配置文件 vim /etc/ ...
- [AGC027A]Candy Distribution Again
Description AGC027A 你有一些糖果,你要把这些糖果一个不剩分给一些熊孩子,但是这帮熊孩子只要特定数目的糖果,否则就会不开心,求最多的开心人数. Solution 如果\(\sum a ...
- 服务端捡起或丢弃指定物品ID触发详解
传奇服务端捡起或丢弃指定物品ID触发详解: @PickUpItemsX X是物品数据库中对应的IDX@DropItemsX X是物品数据库中对应的IDX@H.PickUpItemsX X是物品数据库中 ...
- 力扣MYSQL练习
176编写一个 SQL 查询,获取 Employee 表中第二高的薪水(Salary) . select IFNULL((SELECT distinct salary from employee or ...
- python正则子组匹配
子组匹配返回找到的第一个匹配项 []表示匹配列表中的任意一个,返回找到的第一个 这样可以发现如果要查找字母的话可以使用[a-z],返回找到的第一个字母 查找数字使用[0-9],返回找到的第一个数字相当 ...
- ToolStripComboBox的DataSource和DataTable使用技巧
可以使用Items属性private void GetData() //一下数据均为测试{toolStripComboBox1.Items.Clear(); DataTabl ...
- innerHTML,innerText,textContent
参考理解 https://www.e-learn.cn/content/html/1765240 https://developer.mozilla.org/zh-CN/docs/Web/API/El ...
- class实现React继承以及constructor的super的问题
看这篇文章之前 建议先看看阮一峰 的Class继承 便于更好的理解 首先要知道一个问题 React的父子组件和组件类的继承有什么关系?答案是:没有关系 父子组件:指的得是组件标签包含关系 父子组件通过 ...
- Crawlab-分布式爬虫管理系统
一.简介 Crawlab 基于Celery的爬虫分布式爬虫管理平台,支持多种编程语言以及多种爬虫框架. Github: https://github.com/tikazyq/crawlab 参考资料 ...
- 数据库程序接口——JDBC——API解读第二篇——执行SQL的核心对象
结构图 核心对象 Statement Statement主要用来执行SQL语句.它执行SQL语句的步骤为: 第一步:创建statement对象. 第二步:配置statement对象,此步骤可以忽略. ...