SpringBoot热部署devtool和配置文件自动注入(SpringBoot2.0系列-二)

1、SpringBoot2.x使用Dev-tool热部署

简介:什么是热部署,使用springboot结合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、/META-INF/maven, /META-INF/resources, /resources, /static, /public, or /templates
2、指定文件不进行热部署 spring.devtools.restart.exclude=static/,public/
3、手工触发重启 spring.devtools.restart.trigger-file=trigger.txt
改代码不重启,通过一个文本去控制
https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#using-boot-devtools-restart-exclude

注意点:生产环境不要开启这个功能,如果用java -jar启动,springBoot是不会进行热部署的

2、SpringBoot2.x配置文件讲解

简介:SpringBoot2.x常见的配置文件 xml、yml、properties的区别和使用
xml、properties、json、yaml

1、常见的配置文件 xx.yml, xx.properties

1)YAML(Yet Another Markup Language)

a)写 YAML 要比写 XML 快得多(无需关注标签或引号)
b)使用空格 Space 缩进表示分层,不同层次之间的缩进可以使用不同的空格数目
注意:key后面的冒号,后面一定要跟一个空格,树状结构

2)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 

2、默认示例文件仅作为指导,不要将整个内容复制并粘贴到应用程序中,只挑选需要的属性。

3、参考:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#common-application-properties

如果需要修改,直接复制对应的配置文件,加到application.properties里面

3、SpringBoot注解把配置文件自动映射到属性和实体类

简介:讲解使用@value注解配置文件自动映射到属性和实体类

1、配置文件加载

方式一:

1、Controller上面配置

@PropertySource({“classpath:resource.properties”})

2、增加属性

@Value(“${test.name}”)\

private String name;

方式二:实体类配置文件

步骤:

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、配置文件注入失败,Could not resolve placeholder

解决:根据springboot启动流程,会有自动扫描包没有扫描到相关注解,
默认Spring框架实现会从声明@ComponentScan所在的类的package进行扫描,来自动注入,
因此启动类最好放在根路径下面,或者指定扫描包范围
spring-boot扫描启动类对应的目录和子目录

2、注入bean的方式,属性名称和配置文件里面的key一一对应,就用加@Value 这个注解,
如果不一样,就要加@value(“${XXX}”)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值