profiles.active多環(huán)境開發(fā)、測試、部署過程
1、使用場景
在開始講profiles.active配置時,我們先來考慮幾個場景。
我們在開發(fā)過程中,經常會碰到多個環(huán)境,特別熟數據庫,經常是有開發(fā)庫,測試庫,和生產庫。一般我們都是連的開發(fā)庫進行開發(fā),但是有時候也會需要連接測試庫,甚至是生產庫進行調試工作。我們通常的做法,可能就是直接修改配置文件的數據庫連接,需要連哪個庫就改成哪個庫的連接??墒怯行r候我們改來改去經常出錯,或者不記得哪個環(huán)境的配置了,這時我們可能會想到一次把幾個環(huán)境的配置都寫進來,把不需要的注釋掉,這確實是一種可行的辦法,但還有沒有更好的辦法呢?
再說部署時候的場景。一般我們打包里面包含的都是開發(fā)庫的配置文件,經常部署的時候,需要手動修改部署包里面的配置文件,如果部署到測試環(huán)境,就修改成測試環(huán)境的數據庫,如果是生產環(huán)境,就修改成生產環(huán)境的數據庫。那么有沒有辦法讓一個部署包能同時適配各種不同的環(huán)境呢。
接下來我們要講的profiles.active就可以解決上面的需求。
2、profiles.active
profiles.active表示當前激活的環(huán)境參數,他可以是一個字符數組,但一般情況下,我們都是使用單個字符,例如dev,test,prod來標識。這里我們還是以數據庫配置為例,假設我們原來的application.yml里面配置的數據源是本地數據源,現(xiàn)在我們再來配置一個開發(fā)庫,以dev作為環(huán)境標識。
我們將application.yml復制一份,命名為application-dev.yml,application-{profile-name}.yml,命名規(guī)則就是這樣的。然后我們把dev里面的數據庫名改成spring_boot_study_dev,其他不用的配置刪掉。

這就完成了我們開發(fā)環(huán)境的配置文件編寫。
接著,我們再來一份測試環(huán)境的配置。

這里,我們已經完成了多個環(huán)境配置文件的編寫??梢钥吹?,不同環(huán)境的配置我們寫在不同的配置文件里面,相同的配置我們使用application.yml里面的配置,可以認為是默認配置。我們還差最后一步,使用profiles.active來激活我們當前的需要使用的環(huán)境。
3、profiles.actvie使用
profiles.active配置的方式也有幾種,我們從最簡單的開始。我們可以在application.yml里面直接配置spring.profiles.active屬性。

這樣我們就指定了當前的環(huán)境變量,現(xiàn)在我們來啟動程序。

我們可以看到日志里面打印了當前profiles active 是dev,說明我們的配置生效了,其實我們后面還可以看到程序并沒有啟動完成,因為我們并沒有創(chuàng)建spring_boot_study_dev這個數據庫,這正好再一次證明我們的配置已經生效。

其實在我們以前沒有配置profiles.active時,默認激活的是default。
現(xiàn)在我們可以通過修改spring.profiles.active屬性來快速的切換環(huán)境了。這里筆者要再次提醒一下大家,當我們配置成dev的時候,我們的程序是會讀取application-dev.yml和application.yml兩個配置文件,spring會將兩個配置文件里面的配置進行一個合并,如果兩個文件里面有相同的配置項,將會以application-dev.yml里面的優(yōu)先級為高,即dev里面的配置將會覆蓋默認的配置。
除了改配置文件,我們還可以在eclipse指定環(huán)境變量

通過配置環(huán)境變量,同樣能生效,并且,如果在環(huán)境變量和配置文件同時配置了的情況下,環(huán)境變量的優(yōu)先級會高于配置文件。
這兩種修改spring.profiles.active的方式是開發(fā)時常用的,但是他并不能解決我們部署時候的問題。
假設我們是使用jar包運行,我們可以在執(zhí)行java -jar命令的時候增加-Dspring.profiles.active=test參數的方式指定環(huán)境。

這種配置方式,跟我們修改eclipse環(huán)境變量的原理是一樣的。這樣只要我們部署包里面包含了各個環(huán)境的配置,我們就可以一個部署包直接在多個環(huán)境使用,只需在啟動的時候指定環(huán)境名即可。
那如果是Tomcat部署的war包怎么處理呢。這里以linux版本為例,找到catalina.sh文件,修改JAVA_OPTS參數,增加我們需要配置的環(huán)境變量,這樣只要這個Tomcat里面部署的應用,spring.profiles.active值都是同一個值。

4、總結
這節(jié)主要講如何使用profiles.active這個變量,讓我們在開發(fā)過程快速切換環(huán)境配置,以及如何使一個部署適配各種不同的環(huán)境。如果我們的部署包可以不用修改配置文件,就直接運行,這就為我們以后的自動部署,自動運行掃清了路障。不過,有一點需要注意的是,我們將多個環(huán)境的配置都放到了部署包,會不會存在將其他環(huán)境的敏感配置項泄露給了其他人的情況。
到此這篇關于profiles.active多環(huán)境開發(fā)、測試、部署的文章就介紹到這了,更多相關profiles.active多環(huán)境開發(fā)部署內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java多線程執(zhí)行處理業(yè)務時間太久解決方法代碼示例
這篇文章主要介紹了Java多線程執(zhí)行處理業(yè)務時間太久解決方法代碼示例的相關資料,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12
SpringMVC編程使用Controller接口實現(xiàn)控制器實例代碼
這篇文章主要介紹了SpringMVC編程使用Controller接口實現(xiàn)控制器實例代碼,具有一定參考價值,需要的朋友可以參考下。2017-11-11
java創(chuàng)建excel示例(jxl使用方法)
Java Excel是一開放源碼項目,通過它Java開發(fā)人員可以讀取Excel文件的內容、創(chuàng)建新的Excel文件、更新 已經存在的Excel文件。下面是使用方法,包括去掉網格線、字體設置、單元格設置、對齊方式等設置2014-03-03
簡介Java的Hibernate框架中的Session和持久化類
這篇文章主要介紹了Java的Hibernate框架中的Session和持久化類,Hibernate是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下2015-12-12
springboot整合rabbitmq實現(xiàn)訂單超時取消案例分析
本文介紹了如何使用SpringBoot和RabbitMQ實現(xiàn)訂單超時取消功能,通過配置TTL隊列和死信交換機,可以管理訂單的超時邏輯,實際應用中,可以通過數據庫標記訂單狀態(tài)或手動確認機制來防止訂單被錯誤取消2025-01-01

