spring boot 使用profile來分區配置的操作
很多時候,我們項目在開發環境和生成環境的環境配置是不一樣的,例如,數據庫配置,在開發的時候,我們一般用測試數據庫,而在生產環境的時候,我們是用正式的數據,這時候,我們可以利用profile在不同的環境下配置用不同的配置文件或者不同的配置
spring boot允許你通過命名約定按照一定的格式(application-{profile}.properties)來定義多個配置文件,然后通過在application.properyies通過spring.profiles.active來具體激活一個或者多個配置文件,如果沒有沒有指定任何profile的配置文件的話,spring boot默認會啟動application-default.properties。
profile的配置文件可以按照application.properyies的放置位置一樣,放于以下四個位置,
當前目錄的 “/config”的子目錄下 當前目錄下 classpath根目錄的“/config”包下 classpath的根目錄下在這里我們就定義倆個profile文件,application-cus1.properties和application-cus2.properties,并在倆個文件中都分別寫上變量cusvar=cus1和cusvar=cus2
我們在application.properyies也寫上,并把profile切換到application-cus1.properties的配置文件
cusvar=cus3spring.profiles.active=cus1
可以通過這樣子來測試
@RestController@RequestMapping('/task')public class TaskController { @RequestMapping(value = {'/',''}) public String hellTask(@Value('${cusvar}')String cusvar ){return 'hello task !! myage is ' + cusvar; }}
在這里可以看到spring.profiles.active激活的profile不同,打印出來的結果也不一樣。
除了可以用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: testdbspring.profiles.include: proddb,prodmqspring boot配置之Profile的使用
profile是Spring對不同環境提供不同配置功能的支持,可以通過激活
指定參數等方式快速切換環境
1. 多profile文件形式 格式:application-{profile}.properties 例如常見的:application-dev.properties, application-uat.properties, application-prod.properties2. 多profile文檔塊模式spring: profiles: devserver: port: 8081---spring: profiles: uatserver: port: 8082---spring: profiles: prodserver: port: 8083
1.在默認配置文件application.properties中指定 spring.profiles.active=dev
application.properties文件#激活application-dev.properties中的配置spring.profiles.active=dev
application-dev.properties文件server.port=8081
2.命令行
java -jar ch02-springboot-config-profile-0.0.1-SNAPSHOT.jar --spring.profiles.active=dev
3.虛擬機參數 常用
在'VM options'中添加-Dspring.profiles.active=dev
4.“Program atguments”
在“Program atguments”中添加?spring.profiles.active=dev
SpringBoot啟動會掃描以下位置的application.properties/application.yml文件作為SpringBoot的默認配置文件
file:./config/ file:./ classpath:/config/ classpath:/以上是按照優先級從高到低的順序,所有問題的文件都會被加載。如果配置文件中存在相同配置,則高優先級配置內容會覆蓋低優先級配置內容。SpringBoot會從這四個位置全部加載主配置文件生成一個互補配置的文件。還可通過spring.congif.location改變默認的配置文件位置
以下圖中的優先級為1?>2?>3?>4, 不過1和2不會被打到包里
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章: