相信很多人選擇Spring Boot主要是考慮到它既能兼顧Spring的強(qiáng)大功能晴音,還能實(shí)現(xiàn)快速開發(fā)的便捷柔纵。我們在Spring Boot使用過程中,最直觀的感受就是沒有了原來自己整合Spring應(yīng)用時繁多的XML配置內(nèi)容锤躁,替代它的是在pom.xml
中引入模塊化的Starter POMs
搁料,其中各個模塊都有自己的默認(rèn)配置,所以如果不是特殊應(yīng)用場景系羞,就只需要在application.properties
中完成一些屬性配置就能開啟各模塊的應(yīng)用郭计。
在之前的各篇文章中都有提及關(guān)于application.properties
的使用,主要用來配置數(shù)據(jù)庫連接椒振、日志相關(guān)配置等昭伸。除了這些配置內(nèi)容之外,本文將具體介紹一些在application.properties
配置中的其他特性和使用方法澎迎。
自定義屬性與加載
我們在使用Spring Boot的時候庐杨,通常也需要定義一些自己使用的屬性,我們可以如下方式直接定義:
com.didispace.blog.name=程序猿DD
com.didispace.blog.title=Spring Boot教程
然后通過@Value("${屬性名}")
注解來加載對應(yīng)的配置屬性夹供,具體如下:
@Component
public class BlogProperties {
@Value("${com.didispace.blog.name}")
private String name;
@Value("${com.didispace.blog.title}")
private String title;
// 省略getter和setter
}
按照慣例灵份,通過單元測試來驗證BlogProperties中的屬性是否已經(jīng)根據(jù)配置文件加載了。
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(Application.class)
public class ApplicationTests {
@Autowired
private BlogProperties blogProperties;
@Test
public void getHello() throws Exception {
Assert.assertEquals(blogProperties.getName(), "程序猿DD");
Assert.assertEquals(blogProperties.getTitle(), "Spring Boot教程");
}
}
參數(shù)間的引用
在application.properties
中的各個參數(shù)之間也可以直接引用來使用哮洽,就像下面的設(shè)置:
com.didispace.blog.name=程序猿DD
com.didispace.blog.title=Spring Boot教程
com.didispace.blog.desc=${com.didispace.blog.name}正在努力寫《${com.didispace.blog.title}》
com.didispace.blog.desc
參數(shù)引用了上文中定義的name
和title
屬性填渠,最后該屬性的值就是程序猿DD正在努力寫《Spring Boot教程》
。
使用隨機(jī)數(shù)
在一些情況下鸟辅,有些參數(shù)我們需要希望它不是一個固定的值氛什,比如密鑰、服務(wù)端口等匪凉。Spring Boot的屬性配置文件中可以通過${random}
來產(chǎn)生int值枪眉、long值或者string字符串,來支持屬性的隨機(jī)值再层。
# 隨機(jī)字符串
com.didispace.blog.value=${random.value}
# 隨機(jī)int
com.didispace.blog.number=${random.int}
# 隨機(jī)long
com.didispace.blog.bignumber=${random.long}
# 10以內(nèi)的隨機(jī)數(shù)
com.didispace.blog.test1=${random.int(10)}
# 10-20的隨機(jī)數(shù)
com.didispace.blog.test2=${random.int[10,20]}
通過命令行設(shè)置屬性值
相信使用過一段時間Spring Boot的用戶贸铜,一定知道這條命令:java -jar xxx.jar --server.port=8888
,通過使用--server.port屬性來設(shè)置xxx.jar應(yīng)用的端口為8888树绩。
在命令行運(yùn)行時,連續(xù)的兩個減號--
就是對application.properties
中的屬性值進(jìn)行賦值的標(biāo)識隐轩。所以饺饭,java -jar xxx.jar --server.port=8888
命令,等價于我們在application.properties
中添加屬性server.port=8888
职车,該設(shè)置在樣例工程中可見瘫俊,讀者可通過刪除該值或使用命令行來設(shè)置該值來驗證鹊杖。
通過命令行來修改屬性值固然提供了不錯的便利性,但是通過命令行就能更改應(yīng)用運(yùn)行的參數(shù)扛芽,那豈不是很不安全骂蓖?是的,所以Spring Boot也貼心的提供了屏蔽命令行訪問屬性的設(shè)置川尖,只需要這句設(shè)置就能屏蔽:SpringApplication.setAddCommandLineProperties(false)
登下。
多環(huán)境配置
我們在開發(fā)Spring Boot應(yīng)用時,通常同一套程序會被應(yīng)用和安裝到幾個不同的環(huán)境叮喳,比如:開發(fā)被芳、測試、生產(chǎn)等馍悟。其中每個環(huán)境的數(shù)據(jù)庫地址畔濒、服務(wù)器端口等等配置都會不同,如果在為不同環(huán)境打包時都要頻繁修改配置文件的話锣咒,那必將是個非常繁瑣且容易發(fā)生錯誤的事侵状。
對于多環(huán)境的配置,各種項目構(gòu)建工具或是框架的基本思路是一致的毅整,通過配置多份不同環(huán)境的配置文件趣兄,再通過打包命令指定需要打包的內(nèi)容之后進(jìn)行區(qū)分打包,Spring Boot也不例外毛嫉,或者說更加簡單诽俯。
在Spring Boot中多環(huán)境配置文件名需要滿足application-{profile}.properties
的格式,其中{profile}
對應(yīng)你的環(huán)境標(biāo)識承粤,比如:
-
application-dev.properties
:開發(fā)環(huán)境 -
application-test.properties
:測試環(huán)境 -
application-prod.properties
:生產(chǎn)環(huán)境
至于哪個具體的配置文件會被加載暴区,需要在application.properties
文件中通過spring.profiles.active
屬性來設(shè)置,其值對應(yīng){profile}
值辛臊。
如:spring.profiles.active=test
就會加載application-test.properties
配置文件內(nèi)容
下面仙粱,以不同環(huán)境配置不同的服務(wù)端口為例,進(jìn)行樣例實(shí)驗彻舰。
針對各環(huán)境新建不同的配置文件
application-dev.properties
伐割、application-test.properties
、application-prod.properties
在這三個文件均都設(shè)置不同的
server.port
屬性刃唤,如:dev環(huán)境設(shè)置為1111隔心,test環(huán)境設(shè)置為2222,prod環(huán)境設(shè)置為3333application.properties中設(shè)置
spring.profiles.active=dev
尚胞,就是說默認(rèn)以dev環(huán)境設(shè)置測試不同配置的加載
執(zhí)行
java -jar xxx.jar
硬霍,可以觀察到服務(wù)端口被設(shè)置為1111
,也就是默認(rèn)的開發(fā)環(huán)境(dev)執(zhí)行
java -jar xxx.jar --spring.profiles.active=test
笼裳,可以觀察到服務(wù)端口被設(shè)置為2222
唯卖,也就是測試環(huán)境的配置(test)執(zhí)行
java -jar xxx.jar --spring.profiles.active=prod
粱玲,可以觀察到服務(wù)端口被設(shè)置為3333
,也就是生產(chǎn)環(huán)境的配置(prod)
按照上面的實(shí)驗拜轨,可以如下總結(jié)多環(huán)境的配置思路:
-
application.properties
中配置通用內(nèi)容抽减,并設(shè)置spring.profiles.active=dev
,以開發(fā)環(huán)境為默認(rèn)配置 -
application-{profile}.properties
中配置各個環(huán)境不同的內(nèi)容 - 通過命令行方式去激活不同環(huán)境的配置