本文小編為大家詳細介紹“springboot多環境如何進行動態配置”,內容詳細,步驟清晰,細節處理妥當,希望這篇“springboot多環境如何進行動態配置”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
在springboot中有默認的配置文件application.properties/application.yml文件,前面幾篇分享中一直都是以application.properties文件為例,繼續延用該習慣,且application.properties文件的優先級高于application.yml文件。
在resources目錄下新建application-dev.properties、application-test.properties、application-prod.properties三個配置文件,注意application.properties文件一定要存在,因為它是默認的配置文件。思考下如果沒有application.properties文件,有什么方法可以實現不同環境的配置文件切換,答案是前邊說的“spring.config.name”和“spring.config.location”這兩個屬性,不同環境配置不同的文件名即可。繼續看三個配置文件,
application-dev.properties
server.port=9091
application-test.properties
server.port=9092
application-prod.properties
server.port=9093
另外,在application.properties的配置如下,新加了“spring.profiles.active=test”配置,
server.port=9090spring.profiles.active=test
看下啟動效果,
可以看到這樣就可以實現多環境的動態切換,只需要修改application.properites文件中的“spring.profiles.active”的值即可,注意配置文件需滿足application-${profiles}.properties/yml的格式,${profiles}=dev/test/prod/dev3.....
上面,了解了如何配置多個環境的配置,下面看下如何動態使用。除了上面提到的“spring.profiles.active”還有很多意想不到的。
上面也提到可以使用"spring.config.name"屬性來決定使用哪個配置文件,“spring.config.name”可以配置在JVM參數和環境變量處,且JVM參數的優先級大于環境變量的。下面嘗試下,直接配置在JVM參數處,演示下效果,
這里配置“-Dspring.config.name=application-prod”也就是使用application-prod.properties文件,那么這里的端口肯定是“9093”,看下啟動日志
在不同環境下的多個配置文件,可以使用“spring.config.name”屬性來指定使用哪個環境的文件。不過大多數情況下不建議使用該方式。
在上面也提到了該屬性“spring.profiles.active”注意該屬性和“spring.config.name”的配置值是有區別的,“spring.profiles.active”配置的是application-dev.properties中的“dev“,而“spring.config.name”則配置的是”application-dev“?!眘pring.profiles.active“不僅可以配置在application.properites文件中,還可以配置在JVM變量和環境變量中,下面看下在配置文件和JVM變量中的優先級,
在application.properties文件中配置”spring.profiles.active=test“,
在JVM變量中配置”spring.profiles.active=prod“,
看下啟動日志,
從上圖,可以知道JVM變量的優先級大于application.properties中的配置,也就是說JVM中的”spring.profiles.active“的值會覆蓋application.properties中的”spring.profiles.active“中的值。
我們上面說到的都是需要在啟動的時候配置參數,那么有沒有一種方式可以把配置文件打包在jar包里,在啟動的時候不需要配置參數,直接執行jar即可。下面的這種方式或許可以實現哦。
可以結合maven中的<profiles>標簽動態切換多環境的配置文件,由于這里不再使用”spring.config.name“及”spring.profiles.active“等屬性,所以springboot默認讀取的配置文件依然是”application.properties“文件,既然多環境下都是該文件,那如何做區分吶,看下圖,
沒錯,通過不同的文件夾來區分不同的環境,每個文件夾下的配置文件的內容分別是dev(9091)、test(9092)、prod(9093),那么要如何加載不同的文件,這里要結合pom.xml文件,
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>springTemplate</artifactId> <version>1.0-SNAPSHOT</version> <properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.3.3.RELEASE</version> </dependency> </dependencies> <profiles> <!--dev環境--> <profile> <id>dev</id> <properties> <profiles.active>dev</profiles.active> </properties> <activation> <activeByDefault>true</activeByDefault> </activation> </profile> <!--test環境--> <profile> <id>test</id> <properties> <profiles.active>test</profiles.active> </properties> </profile> <!--prod環境--> <profile> <id>prod</id> <properties> <profiles.active>prod</profiles.active> </properties> </profile> </profiles> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> </plugins> <resources> <resource> <directory>src/main/resources/${profiles.active}</directory> </resource> </resources> </build> </project>
在pom.xml文件中加入了上面的配置,idea的”maven“界面,發生了下面的變化,默認是上面配置的”dev“,
看下選擇了”dev“,服務的啟動日志,
從服務啟動日志可以看到在端口”9091“啟動,也就是使用的是test的配置文件。注意,修改了下圖中的值后,一定要先執行mvn clean,然后執行mvn compie,最后再啟動項目,
使用這樣的方式,在打包的時候就可以根據不同的環境選擇不同的profile,每個環境的包的配置文件是不一樣的。
讀到這里,這篇“springboot多環境如何進行動態配置”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。