-jar jar包启动支持
============
## 2.6.33 版本起开始支持 ##
### 主要升级点
当使用以 -jar 方式启动的程序(非tomcat,web方式)时,例如 springboot 时,可以无缝对接(不会出现配置文件找不到的情况)
### 正确的使用方式
classpath*:autoconfig.properties
### 细节
在未升级前,要使用spring-boot,我们的配置可能是这样的
file:autoconfig.properties
注意,我们使用 `file:autoconfig.properties` 而不是 `classpath*:autoconfig.properties`。这是为什么呢?
当以 -jar 的方式启动服务时,classpath可能会找不到,spring读取配置的原则是:
- `classpath*:autoconfig.properties` : 只能读取jar包内的配置文件
- `file:autoconfig.properties` : 读取的当前路径下的配置文件
当以 java入口类 的方式启动服务时,classpath一定是WEB-INF/classes或者target/classes目录下,spring读取配置的原则是:
- `classpath*:autoconfig.properties` : 读取的WEB-INF/classes或者target/classes目录下的配置文件
- `file:autoconfig.properties` : 读取的是当前路径下的配置文件
在以-jar方式启动时,原则上,我们希望将配置文件放在jar包外面,所以这里采用了 `file:autoconfig.properties`,当以这种方式启动程序时,disconf将配置下载到当前路径下,程序可以找到配置,不会报错。
但当你使用IDE(eclipse or intellij)启动时,它就报错了,说配置文件找不到了。这是因为IDE启动时,不是以-jar的方式启动的,它是以Java入口类的方式进行启动的,disconf将配置下载到target/classes
目录下,如果还是使用`file:autoconfig.properties`,程序在当前路径下是无法找到的。
这就产生了一个问题:我在IDE调试时,必须使用 `classpath*:autoconfig.properties` ,当以命令行启动时,必须使用 `file:autoconfig.properties`
本次升级就是为了避免这个问题。未来配置统一是`classpath*:autoconfig.properties`。原理是,在以-jar启动时,通过将当前路径设置为classpath,程序启动后,disconf将配置下载到当前路径,通过读取classpath进行读取配置,就可以找到这个配置了。