您好,登錄后才能下訂單哦!
前言
痛點:
在java開發的過程中,我們經常要面對各種各樣的環境,比如開發環境,測試環境,正式環境,而這些環境對項目的需求也不相同。
在此之前,我們往往需要手動去修改相對應的配置文件然后打成war,才能部署到相應的環境上。
但是這樣很容易出現問題,因為很容易出現少改或者漏改,造成不必要的麻煩
幻想:
要是有一種東西,能讓我們打war的時候指定一個參數,就能自動把項目編譯成對應環境的war,那該有多幸福啊!!!
結果:這樣的東西還真有,那就是maven-profile
在開發過程中,我們經常會根據不同的環境配置不同的參數,如數據源的ip,username,password、url、秘鑰等都會不同,傳統方式是在一個配置文件中通過修改properties文件中的參數值或者通過注釋解注釋來達到目的,這樣不僅容易出錯,還浪費不必要的時間,更重要的是把代碼發布到測試環境或者生產環境還容易忘記改。為解決這種問題,maven提供了一種解決方案,就是profile。
下圖為傳統方式,需要來回的注釋和解注釋
profile定義的位置
filter方式實現
第一步:分別定義application-dev.properties、application-test.properties、application-pro.properties三個文件
application-dev.properties
env.jdbc.username=dev env.jdbc.password=123456
application-test.properties
env.jdbc.username=test env.jdbc.password=888888
application-pro.properties
env.jdbc.username=root env.jdbc.password=666666
第二步:定義總的屬性文件application.properties,該文件中的值去引用application-<env>.properties中的key
application.properties
// 引用application-<env>中的key jdbc.username=${env.jdbc.username} jdbc.password=${env.jdbc.password} # 公共配置 salt=123456789
第三步:配置profile
<profiles> <profile> <!-- 開發環境 --> <id>dev</id> <properties> <env>dev</env> </properties> <activation> <!-- 設置默認激活這個配置 --> <activeByDefault>true</activeByDefault> </activation> </profile> <profile> <!-- 測試環境 --> <id>test</id> <properties> <env>test</env> </properties> </profile> <profile> <!-- 發布環境 --> <id>pro</id> <properties> <env>pro</env> </properties> </profile> </profiles>
第四步:配置filter和resource
${env}就是在mvn package -P <env>
的名字,這樣就告訴application.properties中應用的key是那個屬性文件的key了
<build> <finalName>profile-app</finalName> <!-- 定義了變量配置文件的地址 --> <filters> <filter>src/main/resources/config/application/application-${env}.properties</filter> </filters> <resources> <resource> <directory>src/main/resources</directory> <filtering>true</filtering> </resource> </resources> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> </plugin> </plugins> </build>
打包運行
// 如果不指定環境,默認是activeByDefault=true的環境,當前是指開發環境 mvn package // 打包指定的環境通過-P 參數,注意p是大寫的 mvn package -P <env>
從mvn packege -P test運行的結果中可以看到生成的target目錄下classes/application.perperties中的jdbc.username和jdbc.password 就是application-test.properties中配置的env.jdbc.username和env.jdbc.password的值。
在spring中如果要使用屬性配置文件,直接引入這個總的配置文件即可,其他的環境配置文件的使命已經結束了。
<context:property-placeholder location="classpath:application.properties"/>
實現原理:
在pom.xml中為每個不同的環境定義不同的profile,每個profile都有一個環境名稱,然后為不同環境定義不同的配置文件(如application-<env>.properties
), 再定義一個總的屬性文件(如application.properties), 然后讓application.properties的value去引用application-<env>.properties
中對應的key,在打包時指定要打包的環境的名稱即可,這樣application.properties中的key的值就是相對應環境application-<env>.properties對應的值了。
多resource實現方式
步驟
第一步:在src/main/resource創建一個env目錄,再創建各個環境的子目錄,再再各個環境子目錄下創建名為config.properties的文件,每個鍵相同,值不同。
env/dev/config.properties
jdbc.username=dev jdbc.password=123456
env/test/config.properties
jdbc.username=test jdbc.password=888888
env/pro/config.properties
jdbc.username=root jdbc.password=666666
第二步:創建一個與環境無關的application.properties
application.properties
# 公共配置 salt=123456789
第三步:配置profiles
<profiles> <profile> <!-- 開發環境 --> <id>dev</id> <properties> <env>dev</env> </properties> <activation> <!-- 設置默認激活這個配置 --> <activeByDefault>true</activeByDefault> </activation> </profile> <profile> <!-- 測試環境 --> <id>test</id> <properties> <env>test</env> </properties> </profile> <profile> <!-- 發布環境 --> <id>pro</id> <properties> <env>pro</env> </properties> </profile> </profiles>
第四步:配置resource
<build> <finalName>profile-app</finalName> <!-- 定義了變量配置文件的地址 --> <resources> <resource> <directory>src/main/resources</directory> <excludes> <exclude>env/dev/*</exclude> <exclude>env/test/*</exclude> <exclude>env/pro/*</exclude> </excludes> <filtering>true</filtering> </resource> <resource> <directory>src/main/resources/env/${env}</directory> <includes> <include>*.*</include> <include>**/*.xml</include> <include>**/*.properties</include> </includes> <filtering>true</filtering> </resource> </resources> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> </plugin> </plugins> </build>
第五步:運行 mvn package -P test
如果經常使用mvn package -P <env>
可以在idea中配置一些maven, 步驟為:Edit Configurations… —– + —- Maven —- 分別為每個環境添加maven 命令,以后雙擊Run Configureations中的任意一個就是相當于運行mvn package -P <env>
命令了
兩種方式比較
filter方式會把所有的application-dev.properties、application-test.properties、application-pro.properties文件都會打包進去,而且此種方式只能針對屬性文件,如果有其他文件(如.xml)也根據不同的環境有不同的配置,這種方式是不好處理。
多resource方式在打包時只打包指定環境的配置文件,可以將各種文件放到各自的環境文件夾中,在打包的時候會將整個文件夾都打包進去。推薦此種方式
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。