溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

springboot指定profiles啟動失敗問題如何解決

發(fā)布時間:2023-05-08 15:48:42 來源:億速云 閱讀:255 作者:iii 欄目:開發(fā)技術

這篇文章主要講解了“springboot指定profiles啟動失敗問題如何解決”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“springboot指定profiles啟動失敗問題如何解決”吧!

    springboot指定profiles啟動失敗

    平常啟動springboot的jar包, 都是通過–spring.profiles.active=dev, 即可讀取application-dev.yml的配置文件的信息,進行啟動

    凡事總有意外

    這次啟動就很奇怪了, 輸入這個啟動環(huán)境參數(shù), 依然不起效果,

    springboot指定profiles啟動失敗問題如何解決

    就是這么驚悚, 就是這么意外!

    沒有讀取application-dev.yml而是讀取默認的application.yml文件

    但是, 使用jvm的啟動參數(shù): java -jar -Dspring.profiles.active=dev, 可以啟動, 證明dev的配置文件是有效的

    比較其他項目

    application的入口類發(fā)現(xiàn):

    public static void main(String[] args){
    	SpringApplication.run(Application.class,args);
    }

    調(diào)用run方法的時候, 沒有傳入args!

    閱讀源碼發(fā)現(xiàn), 傳入啟動參數(shù), 再解析傳入?yún)?shù),對properties進行設置

    注意:

    細心細心, 啟動代碼需要傳入啟動參數(shù)!!! 方能在啟動時,輸入啟動參數(shù)生效

    springboot Profiles、配置文件加載優(yōu)先級

    SpringBoot允許我們有多個配置文件,然后在項目啟動時根據(jù)條件動態(tài)去加載對應的配置文件。

    現(xiàn)在有三個配置,一個默認配置文件(application.properties:因為是SpringBoot指定的名字,所以叫默認配置文件),兩個指定環(huán)境配置文件(application-prod.properties和application-dev.properties:和對應的環(huán)境有關,所以叫它們指定環(huán)境配置文件)

    application-dev.properties

    模擬開發(fā)配置信息

    person.name=ZhangSan
    person.age=18

    application-prod.properties

    就模擬生產(chǎn)配置信息

    person.name=LiSi
    person.age=19

    application.properties

    就指定一個服務的端口號和工程在啟動的時候需要加載的配置文件,SpringBoot會自動去匹配application-{spring.profiles.active}.properties,然后就會找到application-dev.properties配置文件

    server.port=8080
    spring.profiles.active=dev #我們可以指定SpringBoot在啟動時加載那個對應的配置文件

    事例代碼

    創(chuàng)建了一個事例Person類,讓它被實例化的時候從配置文件中讀取信息,讀取規(guī)則:person.{屬性名},讓把創(chuàng)建new一個Person的實例,添加到IOC容器中。

    創(chuàng)建一個get請求,返回我們的Person的事例,我們看perosn的屬性值能否根據(jù)我們在application.properties配置文件中指定spring.profiles.active的屬性加載對應的配置文件,Person實例中的值是不是預期值

    @ConfigurationProperties(prefix = "person") //初始化的時候從配置文件中讀取person.{屬性名}的信息賦值給當前對象
    @Data
    public class Person {
        private String name;
        private Integer age;
    }
     
     
     
    @Configuration //配置文件信息,將Person實例注入到IOC容器中
    public class MyConfig {
     
        @Bean
        public Person person() {
            return new Person();
        }
     
    }

    @RestController //創(chuàng)建一個get請求,返回我們的Person的事例,我們看perosn的屬性值能否根據(jù)我們在application.properties配置文件中指定spring.profiles.active的屬性加載對應的配置文件,Person實例中的值是不是預期值

    @RequestMapping("/user")
    public class PersonController {
     
        @Autowired
        private Person person;
     
        @GetMapping
        public Person getPerson() {
            return person;
        }
    }

    工程跑起來,訪問http://localhost:8080/user,返回結果:

    {"name":"ZhangSan","age":18}

    把application.properties中的spring.profiles.active的值修改成prod,請求訪問http://localhost:8080/user,返回結果:

    {"name":"LiSi","age":19}

    另外如果我們已經(jīng)將工程打包成jar,可以在啟動SpringBoot工程的時候,通過命令行給參數(shù)賦值的方式指定spring.profiles.active的值

    java -jar .\web-02-0.0.1-SNAPSHOT.jar --spring.profiles.active=dev

    還有一個比較實用的,就是SpringBoot默認加載application.properties和application.yaml的路徑和優(yōu)先級(從SpringBoot官方文檔中看到的:https://docs.spring.io/spring-boot/docs/current/reference/html/features.html#features.external-config.application-json),加載的優(yōu)先級:

    • jar包所在的目錄下面的/config/{一級子目錄}下面的application.properties和application.yaml

    • jar包所在的目錄下面的/config下面的application.properties和application.yaml

    • jar包所在的目錄下面的application.properties和application.yaml

    • classpath下面/config里面的application.properties和application.yaml

    • classpath下面的application.properties和application.yaml

    場景就是:我們的項目跑了很久了,突發(fā)情況需要修改配置文件。但是以前的老配置文件我們也不敢隨意修改,這個時候我們就可以在優(yōu)先級高的地方放我們的新的配合文件了。

    感謝各位的閱讀,以上就是“springboot指定profiles啟動失敗問題如何解決”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對springboot指定profiles啟動失敗問題如何解決這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節(jié)

    免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

    AI