首頁 > 軟體

java啟動時自定義組態檔路徑,自定義log4j2.xml位置方式

2022-08-26 18:02:27

java啟動時自定義組態檔路徑,自定義log4j2.xml位置

啟動時指定組態檔位置

專案打成jar包後,組態檔會一起打包到jar包的classes下,這就是所說的classpath。比如spring boot 就是在jarBOOT-INFclasses下

然後在jar檔案執行時,就會自動去jar檔案內找組態檔,這對我們部署服務是不利的,通常都是將組態檔放在外面,方便修改設定內容。

有一種說法:說組態檔載入順序為(由高到低)

  • jar包同級目錄下的config資料夾下設定
  • jar包同級目錄下設定
  • classpath下config目錄下設定
  • classpath下設定

經驗證

application.properties   或者 application.yml 是上面的載入順序,但是我在搭建spring boot 專案時 【jar包同級目錄下的config資料夾下設定】優先順序是 > 【classpath下設定】,但是 【jar包同級目錄下設定】優先順序並沒有【classpath下設定】的高。。不知為何。不過把組態檔放到  jar包同級目錄下的config資料夾是能夠解決需求的。

後來又發現一個問題

外部log4j2.xml 載入不到,不管是放在jar同級目錄,還是jar包同級目錄下的config,都不起作用,每次啟動都加在 jar包內的log4j2.xml ,查了很多資料都說不到點上。

後面終於找到解決辦法了,就是在啟動jar檔案的時候手動載入,如下(start.sh內容)

name="my-web"
pid=`ps -ef | grep ${name} | grep -v grep |awk '{print $2}'`
if [ $pid ]; then
    echo  ${name}  is  running pid=$pid
    kill -9 $pid
fi
nohup  java -Xms100m -Xmx100m  -jar ../${name}-0.0.1-SNAPSHOT.jar --logging.config=../config/log4j2.xml > ../logs/${name}.log & tail -f ../logs/${name}.log

就是加上 【--logging.config=config/log4j2.xml】 來制定載入的 log4j2.xml

如果啟動不了

pom 可能沒有加上依賴

<!--  紀錄檔依賴-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>
 
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>

最後附上整個檔案的目錄結構

my-web
----bin
    ----start.sh
    ----stop.sh
----config
    ----log4j2.xml
    ----application.yml
    ----application.properties
----logs
----my-web.jar

java服務啟動指定組態檔路徑

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com