前两章学习的时候发现,项目中改代码或是配置的时候都需要启动项目,这在实际开发中效率是非常低的,所以我们有了热部署的概念。
一.热部署的概念
1. 热部署:就是用插件去监听我们的java文件和classpath类文件变化,如果监听到有变化,就启动类加载器,比如是java文件就加载到虚拟机JVM中,这样我们就可以直接应用,而不用去启动应用了,springboot提供的热加载器工具是dev-tool工具。
dev-tool官方地址:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#using-boot-devtools
项目中需要加的依赖 核心依赖包:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
添加依赖后,在ide里面重启应用,后续 修改后马上可以生效
二.测试热部署
1. 加入上面的依赖之后,启动项目
我们用第二章随便选一个案例
2)现在我们简单加入打印一行代码
2.注意:控制台又再一次自己启动工程,但是这次启动比第一次启动快很多,因为它只是加载了你修改的部分
3.我们访问一下
控制台
4.总结:
不被热部署的文件
/META-INF/maven, /META-INF/resources, /resources, /static, /public, or /templates
5. 指定文件不进行热部署
默认application.properties文件是在监听范围的(修改里面的内容,项目会启动)
而在项目中一般我们不希望修改application.properties的时候就启动工程,于是我们可以
指定文件不进行热部署 spring.devtools.restart.exclude=static/**,public/**
1)在application.properties配置
注意:配置后一定要重新启动工程才生效
2)现在我们对application.properties进行修改发现项目没有启动
6.手工触发重启
有时候我们希望手动去触发启动application.properties配置:spring.devtools.restart.trigger-file=trigger.txt
改代码不重启,通过一个文本去控制
1)
2).在src/main/resources文件下创建trigger.txt文件
3)重新启动工程,然后修改我们刚刚的例子
保存后发现我们的工程没有启动
4)将trigger.txt文件改之后保存,发现工程启动了,这就是手动触发,在实际开发中这也是比较好用的。
三.SpringBoot2.x配置文件讲解
1.简介:SpringBoot2.x常见的配置文件 xml、yml、properties的区别和使用
xml、properties、json、yaml
1、常见的配置文件 xx.yml, xx.properties,
1)YAML(Yet Another Markup Language)
写 YAML 要比写 XML 快得多(无需关注标签或引号)
使用空格 Space 缩进表示分层,不同层次之间的缩进可以使用不同的空格数目
注意:key后面的冒号,后面一定要跟一个空格,树状结构
2.yml和properties对比
application.properties示例
server.port=8090
server.session-timeout=30
server.tomcat.max-threads=0
server.tomcat.uri-encoding=UTF-8
application.yml示例
server:
port: 8090
session-timeout: 30
tomcat.max-threads: 0
tomcat.uri-encoding: UTF-8
yml的文档在此开始查看
三.SpringBoot注解把配置文件自动映射到属性和实体类实战
1. 简介:讲解使用@value注解配置文件自动映射到属性和实体类
配置文件加载
方式一
1、Controller上面配置
@PropertySource({"classpath:resource.properties"})
2、增加属性
@Value("${test.name}")
private String name;
1)
2)
3)
4)启动工程,也可以用之前配置好的手动启动方式
原理总结:当spring扫描到controller包下@PropertySource({"classpath:application.properties"})注解时,会让bean管理,并将application.properties里面的属性映射成map,然后通过 @Value("${web.po.lan}")注解将D:/pic/注入给filePath.
${web.po.lan}:就是获取配置文件里面web.po.lan对应的值,即D:/pic/
2.方式二:实体类配置文件
步骤:
1、添加 @Component 注解;
2、使用 @PropertySource 注解指定配置文件位置;
3、使用 @ConfigurationProperties 注解,设置相关属性;
4、必须 通过注入IOC对象Resource 进来 , 才能在类中使用获取的配置文件值。
@Autowired
private ServerSettings serverSettings;
例子:
@Configuration
@ConfigurationProperties(prefix="test")
@PropertySource(value="classpath:resource.properties")
public class ServerConstant {
1) 建立实体类
2)在application.properties文件下配置如下
3)选一个controller类
4)
变形上面的例子
变形一:
1)
2)修改后启动工程访问即可
变形二:修改@ConfigurationProperties(prefix="...")prefix的内容
1)
2)
3)