目录
- 导读
- 一、application.properties外置
- 二、@PropertySource外置
- 总结
导读
有些时候,我们的一些配置信息需要比较频繁的修改,如果这些配置信息是放在项目中的话,那么就需要经常进行打包部署,所以我们就思考是否可以把这个配置文件外置呢?
一、application.properties外置
大部分的配置信息,我们都是配置在application.properties,那么这个文件是否可以外置呐?这个当然是可以的。
首先在application.preperties定义一个属性:
demo.name = hello.01
在Controller进行使用:
@Value("${demo.name}") private String demoName; @RequestMapping("/test") public String test(){ return this.demoName; }
将项目打成jar包,使用Java -jar的方式进行启动:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar
此时读取的值是:hello.01。
将项目中php的application.properties拷贝出来,放到和jar包同路径下,修改属性值为:
demo.name = hello.02
然后使用上面的命令重新启动,看下效果读取的值就是hello.02了,惊不惊喜意不意外,Spring Boo开发者_自学开发t太牛了,jar包同路径下就直接读取了。
如果我们在jar下新建一个config,然后把application.properties放进去的话,使用上面的命令可以识别吗 ?答案是可以的,
SpringApplication 将从 application.properties 以下位置的文件中加载属性并且将其添加到 Spring 的环境当中:
- 当前目录下的 /config 子目录
- classpath根目录
- classpath中的 /config 目录
- 当前目录
如果自定义的目录,比如conf的话,这个时候就不能识别了,但可以使用--spring.config.lophpcation进行指定路径,执行命令如下:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.j编程客栈ar--spring.config.location=conf/application.properties
当然也可以使用绝对路径进行指定:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar--spring.config.location=/Users/linxiangxian/Downloads/conf/application.properties
更多内容请关注公众号【Java技术迷】,获取更多精彩内容!
二、@PropertySource外置
在项目中,有些配置会自定义propreties文件进行使用,比如定义了demo.properties:
demo.nickname = hello.10 demo.weixin = springboot
使用@PropertySource指定配置文件:
/** * @PropertySource的例子 * <p> */ @Configuration @ConfigurationProperties(prefix = "demo") @PropertySource(value = {"classpath:demo.properties"}) public class DemoProperties { private String nickname; private String weixin; public String getNickname() { return nickname; } public void setNickname(String nickname) { this.nickname = nickname; } public String getWeixin() { return weixin; } public void setWeixin(String weixin) { this.weixin编程客栈 = weixin; } @Override public String toString() { return "DemoProperties{" + "nickname='" + nickname + '\'' + ", weixin='" + weixin + '\'' + '}'; } }
那么此时是可以访问到这个配置文件的,打成jar包,执行命令:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar
此时返回的值是:hello.10
将demo.properties放到和jar包同路径下,修改demo.name的值为hello.11,执行上面的命令,芭比Q了,结果还是hello.10,说明Spring Boot对于自定义的properties文件并不能自己从外部去寻找。
那对于这个问题咱么破呢?
很简单,@PropertySource支持多配置多个路径,可以这么配置:
@PropertySource(value = {"classpath:demo.properties","file:./demo.properties"},ignoreResourceNotFound = 编程客栈true)
当我们配置多路径,且多路径下配置文件都存在时,SpringBoot会都加载且会覆盖相同内容。所以当我们配置信息只区分外部和内部路径、内容完全相同时,将file路径写在后面就可以了。当我们本地启动时,因为不存在file路径,所以会加载classpath;当jar启动时,file路径会覆盖classpath路径下的内容;
ignoreResourceNotFound = true 一定要加上,否则找不到会报错。加上之后会忽略找不到的配置文件。
此时将配置文件demo.properties放到和jar包同级下就可以了。
总结
对于 application.properties 文件:
(1)默认是读取classpath下的application.properties文件。
(2)jar包同级下的application.properties可以直接读取,启动命名不需要做调整。
(3)jar包同级下的config/application.properties,可以直接读取,启动命令不需要调整。
(4)jar包同级下的conf/application.properties,不可以直接读取,需要通过参数--spring.config.location进行指定。
对于自定义的 .properties 文件:
(1)默认是读取classpath下的xxx.properties文件。
(2)jar包同级下的xxx.properties不可以直接读取,需要修改代码的配置@PropertySource指定多个路径,期望最终被使用的路径放到最后,因为会覆盖之前读取的配置信息。
Spring Boot将从 application.properties 以下位置的文件中加载属性并且将其添加到 Spring 的环境当中:
- 当前目录下的 /config 子目录
- classpath根目录
- classpath中的 /config 目录
- 当前目录
到此这篇关于SpringBoot 项目打成 jar后加载外部配置文件的操作方法的文章就介绍到这了,更多相关SpringBoot 加载外部配置文件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
精彩评论