您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何理解springboot中配置文件application.properties”,在日常操作中,相信很多人在如何理解springboot中配置文件application.properties問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何理解springboot中配置文件application.properties”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
Spring Boot使用“習慣優于配置”(項目中存在大量的配置,此外還內置了一個習慣性的配置,讓你無需手動進行配置)的理念讓你的項目快速運行起來。所以,我們要想把Spring Boot玩的溜,就要懂得如何開啟各個功能模塊的默認配置,這就需要了解Spring Boot的配置文件application.properties。
Spring Boot使用了一個全局的配置文件application.properties,放在src/main/resources目錄下或者類路徑的/config下。Sping Boot的全局配置文件的作用是對一些默認配置的配置值進行修改。
接下來,讓我們一起來解開配置文件的面紗。
注:如果你工程沒有這個application.properties,那就在src/main/java/resources目錄下新建一個。
application.properties提供自定義屬性的支持,這樣我們就可以把一些常量配置在這里:
com.dudu.name="嘟嘟MD" com.dudu.want="祝大家雞年大吉吧"
然后直接在要使用的地方通過注解@Value(value="${config.name}")就可以綁定到你想要的屬性上面
@RestController public class UserController { @Value("${com.dudu.name}") private String name; @Value("${com.dudu.want}") private String want; @RequestMapping("/") public String hexo(){ return name+","+want; } }
我們啟動工程輸入http://localhost:8080 就可以看到打印了"嘟嘟MD祝大家雞年大吉吧"。
有時候屬性太多了,一個個綁定到屬性字段上太累,官方提倡綁定一個對象的bean,這里我們建一個ConfigBean.java類,頂部需要使用注解@ConfigurationProperties(prefix = "com.dudu")來指明使用哪個
@ConfigurationProperties(prefix = "com.dudu") public class ConfigBean { private String name; private String want; // 省略getter和setter }
這里配置完還需要在spring Boot入口類加上@EnableConfigurationProperties并指明要加載哪個bean,如果不寫ConfigBean.class,在bean類那邊添加
@SpringBootApplication @EnableConfigurationProperties({ConfigBean.class}) public class Chapter2Application { public static void main(String[] args) { SpringApplication.run(Chapter2Application.class, args); } }
最后在Controller中引入ConfigBean使用即可,如下:
@RestController public class UserController { @Autowired ConfigBean configBean; @RequestMapping("/") public String hexo(){ return configBean.getName()+configBean.getWant(); } }
在application.properties中的各個參數之間也可以直接引用來使用,就像下面的設置:
com.dudu.name="嘟嘟MD" com.dudu.want="祝大家雞年大吉吧" com.dudu.yearhope=${com.dudu.name}在此${com.dudu.want}
這樣我們就可以只是用yearhope這個屬性就好
有時候我們不希望把所有配置都放在application.properties里面,這時候我們可以另外定義一個,這里我明取名為test.properties,路徑跟也放在src/main/resources下面。
com.md.name="喲西~" com.md.want="祝大家雞年,大吉吧"
我們新建一個bean類,如下:
@Configuration @ConfigurationProperties(prefix = "com.md") @PropertySource("classpath:test.properties") public class ConfigTestBean { private String name; private String want; // 省略getter和setter }
這里要注意哦,有一個問題,如果你使用的是1.5以前的版本,那么可以通過locations指定properties文件的位置,這樣:
@ConfigurationProperties(prefix = "com.md",locations="classpath:test.properties")
但是1.5版本后就沒有這個屬性了,找了半天發現添加@Configuration和@PropertySource("classpath:test.properties")后才可以讀取。
配置文件中${random} 可以用來生成各種不同類型的隨機值,從而簡化了代碼生成的麻煩,例如 生成 int 值、long 值或者 string 字符串。
dudu.secret=${random.value} dudu.number=${random.int} dudu.bignumber=${random.long} dudu.uuid=${random.uuid} dudu.number.less.than.ten=${random.int(10)} dudu.number.in.range=${random.int[1024,65536]}
Spring Boot是基于jar包運行的,打成jar包的程序可以直接通過下面命令運行:
java -jar xx.jar
可以以下命令修改tomcat端口號:
java -jar xx.jar --server.port=9090
可以看出,命令行中連續的兩個減號--就是對application.properties中的屬性值進行賦值的標識。
所以java -jar xx.jar --server.port=9090等價于在application.properties中添加屬性server.port=9090。
如果你怕命令行有風險,可以使用SpringApplication.setAddCommandLineProperties(false)禁用它。
實際上,Spring Boot應用程序有多種設置途徑,Spring Boot能從多重屬性源獲得屬性,包括如下幾種:
根目錄下的開發工具全局設置屬性(當開發工具激活時為~/.spring-boot-devtools.properties)。
測試中的@TestPropertySource注解。
測試中的@SpringBootTest#properties注解特性。
命令行參數
SPRING_APPLICATION_JSON中的屬性(環境變量或系統屬性中的內聯JSON嵌入)。
ServletConfig初始化參數。
ServletContext初始化參數。
java:comp/env里的JNDI屬性
JVM系統屬性
操作系統環境變量
隨機生成的帶random.* 前綴的屬性(在設置其他屬性時,可以應用他們,比如${random.long})
應用程序以外的application.properties或者appliaction.yml文件
打包在應用程序內的application.properties或者appliaction.yml文件
通過@PropertySource標注的屬性源
默認屬性(通過SpringApplication.setDefaultProperties指定).
這里列表按組優先級排序,也就是說,任何在高優先級屬性源里設置的屬性都會覆蓋低優先級的相同屬性,列如我們上面提到的命令行屬性就覆蓋了application.properties的屬性。
application.properties和application.yml文件可以放在一下四個位置:
外置,在相對于應用程序運行目錄的/congfig子目錄里。
外置,在應用程序運行的目錄里
內置,在config包內
內置,在Classpath根目錄
同樣,這個列表按照優先級排序,也就是說,src/main/resources/config下application.properties覆蓋src/main/resources下application.properties中相同的屬性,如圖:
此外,如果你在相同優先級位置同時有application.properties和application.yml,那么application.yml里面的屬性就會覆蓋application.properties里的屬性。
當應用程序需要部署到不同運行環境時,一些配置細節通常會有所不同,最簡單的比如日志,生產日志會將日志級別設置為WARN或更高級別,并將日志寫入日志文件,而開發的時候需要日志級別為DEBUG,日志輸出到控制臺即可。
如果按照以前的做法,就是每次發布的時候替換掉配置文件,這樣太麻煩了,Spring Boot的Profile就給我們提供了解決方案,命令帶上參數就搞定。
這里我們來模擬一下,只是簡單的修改端口來測試
在Spring Boot中多環境配置文件名需要滿足application-{profile}.properties的格式,其中{profile}對應你的環境標識,比如:
application-dev.properties:開發環境
application-prod.properties:生產環境
想要使用對應的環境,只需要在application.properties中使用spring.profiles.active屬性來設置,值對應上面提到的{profile},這里就是指dev、prod這2個。
當然你也可以用命令行啟動的時候帶上參數:
java -jar xxx.jar --spring.profiles.active=dev
我給不同的環境添加不同的端口屬性server.port,然后根據指定不同的spring.profiles.active來切換使用。各位可以自己試試。這里就不貼代碼了。
除了可以用profile的配置文件來分區配置我們的環境變量,在代碼里,我們還可以直接用@Profile注解來進行配置,例如數據庫配置,這里我們先定義一個接口
public interface DBConnector { public void configure(); }
分別定義倆個實現類來實現它
/** * 測試數據庫 */ @Component @Profile("testdb") public class TestDBConnector implements DBConnector { @Override public void configure() { System.out.println("testdb"); } } /** * 生產數據庫 */ @Component @Profile("devdb") public class DevDBConnector implements DBConnector { @Override public void configure() { System.out.println("devdb"); } }
通過在配置文件激活具體使用哪個實現類
spring.profiles.active=testdb
然后就可以這么用了
@RestController @RequestMapping("/task") public class TaskController { @Autowired DBConnector connector ; @RequestMapping(value = {"/",""}) public String hellTask(){ connector.configure(); //最終打印testdb return "hello task !! myage is " + myage; } }
除了spring.profiles.active來激活一個或者多個profile之外,還可以用spring.profiles.include來疊加profile
spring.profiles.active: testdb spring.profiles.include: proddb,prodmq
到此,關于“如何理解springboot中配置文件application.properties”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。