SpringBoot項(xiàng)目部署時(shí)application.yml文件的加載優(yōu)先級(jí)和啟動(dòng)腳本問(wèn)題
application.yml文件的加載優(yōu)先級(jí)(由高到低)
第一級(jí)命令行參數(shù)
java -jar demo.jar --spring.config.location=/path/to/application.yml
- 這個(gè)是在系統(tǒng)啟動(dòng)參數(shù)中直接指定,這個(gè)一般不用
第二級(jí)Jar包同級(jí)目錄 /config
/path/to/demo.jar---jar包位置 /path/to/config/application.yml---配置文件位置
- 2級(jí)與3級(jí)留做系統(tǒng)打包后設(shè)置通用屬性,2級(jí)常用于運(yùn)維經(jīng)理進(jìn)行線上整體項(xiàng)目部署方案調(diào)控,
如下是 Jar包同級(jí)目錄/config的情況,在**/config**文件夾下配置了的話,會(huì)覆蓋外面application.yml的配置和jar包內(nèi)部的application.yml配置

第三級(jí)Jar包同級(jí)目錄
/path/to/demo.jar---jar包位置 /path/to/application.yml---配置文件位置
- 2級(jí)與3級(jí)留做系統(tǒng)打包后設(shè)置通用屬性,3級(jí)服務(wù)于運(yùn)維人員配置涉密線上環(huán)境
如下是Jar包同級(jí)目錄的情況,會(huì)將配置的內(nèi)容替換jar包里面原有的application.yml配置

第四級(jí)classpath 下的/config
src/main/resources/config/application.yml
- 4級(jí)和5級(jí)用于系統(tǒng)開(kāi)發(fā)階段設(shè)置通用屬性,4級(jí)常用于項(xiàng)目經(jīng)理進(jìn)行整體項(xiàng)目屬性調(diào)控
第五級(jí)classpath 根路徑/
src/main/resources/application.yml
- 4級(jí)和5級(jí)用于系統(tǒng)開(kāi)發(fā)階段設(shè)置通用屬性,5級(jí)服務(wù)于開(kāi)發(fā)人員本機(jī)開(kāi)發(fā)與測(cè)試
總結(jié):
- 多層級(jí)配置文件間的屬性采用疊加并覆蓋的形式作用于程序。
- 如果同一個(gè)目錄下,有application.yml也有application.properties,默認(rèn)先讀取application.properties。
- 如果同一個(gè)配置屬性,在多個(gè)配置文件都配置了,默認(rèn)使用第1個(gè)讀取到的,后面讀取的不覆蓋前面讀取到的。
- 先后加載順序:若application 和bootstrap 在同一目錄下:bootstrap先加載 application后加載
logback.xml 文件加載順序
Spring Boot 在部署時(shí)會(huì)按照特定的順序嘗試加載 logback.xml 配置文件。以下是加載 logback.xml 的常見(jiàn)位置和加載順序:
- 外部配置文件:通過(guò)命令行參數(shù)指定的外部配置文件。例如,使用 --spring.config.location 參數(shù)指定配置文件路徑。
- 當(dāng)前目錄下的 /config 子目錄
- 當(dāng)前目錄
- 類路徑下的 /config 包
- 類路徑的根目錄
logback.xml 將會(huì)按照上述順序依次查找,并使用找到的第一個(gè)配置文件。
如果你想要指定 logback.xml 的加載位置,可以在啟動(dòng) Spring Boot 應(yīng)用時(shí)通過(guò)命令行參數(shù) --spring.config.location 指定。
例如:
java -jar demo.jar --spring.config.location=file:/path/to/config/
注意:
- springboot在啟動(dòng)初,會(huì)加載內(nèi)部的logback.xml,完全啟動(dòng)后,才會(huì)加載外部的logback.xml,所以最好保持兩者一致
當(dāng)application.yml 和 bootstrap.yml 同時(shí)存在時(shí)
- 則bootStrap.yml 的加載順序要于application.yml,即bootStrap.yml 會(huì)優(yōu)先被加載。
原理:
- bootstrap.yml 于應(yīng)程序上下的引導(dǎo)階段。
- bootstrap.yml 由Spring ApplicationContext加載。
- bootstrap.yml 可以理解成系統(tǒng)級(jí)別的?些參數(shù)配置,這些參數(shù)?般是不會(huì)變動(dòng)的。
- application.yml 可以?來(lái)定義應(yīng)?級(jí)別的,如果搭配 spring-cloud-config 使用 application.yml 定義的文件可以實(shí)現(xiàn)動(dòng)態(tài)替換。
java jar包啟動(dòng)腳本
最簡(jiǎn)單的啟動(dòng)腳本
java -jar demo.jar
后臺(tái)運(yùn)行并打印日志
#日志打印輸出 nohup java -jar demo.jar >nohup.log 2>&1 &
一個(gè)通用腳本
- jar包同級(jí)目錄下創(chuàng)建logs文件夾
- jar包同級(jí)目錄下創(chuàng)建config文件夾,包含application.yml 和logback.xml 文件,給777權(quán)限
腳本如下:
#!/bin/sh
# 該腳本為L(zhǎng)inux下啟動(dòng)java程序的腳本
#
# 特別注意:
# 該腳本使用系統(tǒng)kill命令來(lái)強(qiáng)制終止指定的java程序進(jìn)程。
# 所以在殺死進(jìn)程前,可能會(huì)造成數(shù)據(jù)丟失或數(shù)據(jù)不完整。如果必須要考慮到這類情況,則需要改寫此腳本,
#
#
# 根據(jù)實(shí)際情況來(lái)修改以下配置信息 ##################################
# JAVA應(yīng)用程序的名稱
APP_NAME=xxxx系統(tǒng)
BASEPATH=$(cd `dirname $0`;pwd)
# jar包名稱-記得更改
JAR_NAME=demo.jar
# PID 代表是PID文件
JAR_PID=$JAR_NAME\.pid
# java虛擬機(jī)啟動(dòng)參數(shù)
JAVA_OPTS="-Xms512m -Xmx2048m -XX:MetaspaceSize=512m -XX:MaxMetaspaceSize=512m -XX:ParallelGCThreads=16 -XX:+PrintGCDateStamps -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=utf-8"
# 根據(jù)實(shí)際情況來(lái)修改以上配置信息 ##################################
# 檢查程序是否處于運(yùn)行狀態(tài)
is_exist() {
# 查詢出應(yīng)用服務(wù)的進(jìn)程id,grep -v 是反向查詢的意思,查找除了grep操作的run.jar的進(jìn)程之外的所有進(jìn)程
pid=`ps -ef|grep $JAR_NAME|grep -v grep|awk '{print $2}' `
# [ ]表示條件測(cè)試。注意這里的空格很重要。要注意在'['后面和']'前面都必須要有空格
# [ -z STRING ] 如果STRING的長(zhǎng)度為零則返回為真,即空是真
# 如果不存在返回0,存在返回1
if [ -z "${pid}" ]; then
return 0
else
return 1
fi
}
# ######### Shell腳本中$0、$?、$!、$$、$*、$#、$@等的說(shuō)明 #########
# $$ Shell本身的PID(ProcessID,即腳本運(yùn)行的當(dāng)前 進(jìn)程ID號(hào))
# $! Shell最后運(yùn)行的后臺(tái)Process的PID(后臺(tái)運(yùn)行的最后一個(gè)進(jìn)程的 進(jìn)程ID號(hào))
# $? 最后運(yùn)行的命令的結(jié)束代碼(返回值)即執(zhí)行上一個(gè)指令的返回值 (顯示最后命令的退出狀態(tài)。0表示沒(méi)有錯(cuò)誤,其他任何值表明有錯(cuò)誤)
# $- 顯示shell使用的當(dāng)前選項(xiàng),與set命令功能相同
# $* 所有參數(shù)列表。如"$*"用「"」括起來(lái)的情況、以"$1 $2 … $n"的形式輸出所有參數(shù),此選項(xiàng)參數(shù)可超過(guò)9個(gè)。
# $@ 所有參數(shù)列表。如"$@"用「"」括起來(lái)的情況、以"$1" "$2" … "$n" 的形式輸出所有參數(shù)。
# $# 添加到Shell的參數(shù)個(gè)數(shù)
# $0 Shell本身的文件名
# $1~$n 添加到Shell的各參數(shù)值。$1是第1參數(shù)、$2是第2參數(shù)…。
# 服務(wù)啟動(dòng)方法
start() {
is_exist
if [ $? -eq "1" ]; then
echo "$APP_NAME is already running pid is ${pid}"
else
# jar服務(wù)啟動(dòng)腳本
nohup java $JAVA_OPTS -jar -Dlogging.config=./config/logback.xml $BASEPATH/$JAR_NAME >> ${BASEPATH}/logs/nohup.out 2>&1 &
echo $! > $JAR_PID
echo "start $APP_NAME successed pid is $! "
tail -100f ${BASEPATH}/logs/nohup.out
fi
}
# 服務(wù)停止方法
stop() {
# is_exist
pidf=$(cat $JAR_PID)
# echo "$pidf"
echo "pid = $pidf begin kill $pidf"
kill $pidf
rm -rf $JAR_PID
sleep 2
# 判斷服務(wù)進(jìn)程是否存在
is_exist
if [ $? -eq "1" ]; then
echo "pid = $pid begin kill -9 $pid"
kill -9 $pid
sleep 2
echo "$APP_NAME process stopped!"
else
echo "$APP_NAME is not running!"
fi
}
# 服務(wù)運(yùn)行狀態(tài)查看方法
status() {
is_exist
if [ $? -eq "1" ]; then
echo "$APP_NAME is running,pid is ${pid}"
else
echo "$APP_NAME is not running!"
fi
}
# 重啟服務(wù)方法
restart() {
# 調(diào)用服務(wù)停止命令
stop
# 調(diào)用服務(wù)啟動(dòng)命令
start
}
# 幫助說(shuō)明,用于提示輸入?yún)?shù)信息
usage() {
echo "Usage: sh run-service.sh [ start | stop | restart | status ]"
exit 1
}
###################################
# 讀取腳本的第一個(gè)參數(shù)($1),進(jìn)行判斷
# 參數(shù)取值范圍:{ start | stop | restart | status }
# 如參數(shù)不在指定范圍之內(nèi),則打印幫助信息
###################################
#根據(jù)輸入?yún)?shù),選擇執(zhí)行對(duì)應(yīng)方法,不輸入則執(zhí)行使用說(shuō)明
case "$1" in
'start')
start
;;
'stop')
stop
;;
'restart')
restart
;;
'status')
status
;;
*)
usage
;;
esac
exit 0
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- springboot無(wú)法加載yml配置文件的解決方案
- SpringBoot使用不同環(huán)境動(dòng)態(tài)加載不同配置文件
- SpringBoot配置文件啟動(dòng)加載順序的方法步驟
- SpringBoot配置文件的優(yōu)先級(jí)順序、加載順序、bootstrap.yml與application.yml區(qū)別及說(shuō)明
- SpringBoot中的配置文件加載優(yōu)先級(jí)詳解
- SpringBoot加載不出來(lái)application.yml文件的解決方法
- SpringBoot項(xiàng)目加載配置文件的6種方式小結(jié)
- SpringBoot實(shí)現(xiàn)配置文件自動(dòng)加載和刷新的示例詳解
- SpringBoot的配置文件application.yml及加載順序詳解
- springboot加載配值文件的實(shí)現(xiàn)步驟
相關(guān)文章
Java語(yǔ)言多線程終止中的守護(hù)線程實(shí)例
這篇文章主要介紹了Java語(yǔ)言多線程終止中的守護(hù)線程實(shí)例,具有一定借鑒價(jià)值,需要的朋友可以參考下2017-12-12
手把手帶你掌握SpringBoot RabbitMQ延遲隊(duì)列
RabbitMQ 是一個(gè)由Erlang語(yǔ)言開(kāi)發(fā)的AMQP的開(kāi)源實(shí)現(xiàn),支持多種客戶端。用于在分布式系統(tǒng)中存儲(chǔ)轉(zhuǎn)發(fā)消息,在易用性、擴(kuò)展性、高可用性等方面表現(xiàn)不俗,下文將帶你深入了解 RabbitMQ 延遲隊(duì)列2021-09-09
SpringBoot應(yīng)用啟動(dòng)過(guò)程分析
這篇文章主要介紹了SpringBoot應(yīng)用啟動(dòng)過(guò)程分析,需要的朋友可以參考下2017-08-08
SpringCloud使用Feign實(shí)現(xiàn)遠(yuǎn)程調(diào)用流程詳細(xì)介紹
OpenFeign源于Netflix的Feign,是http通信的客戶端。屏蔽了網(wǎng)絡(luò)通信的細(xì)節(jié),直接面向接口的方式開(kāi)發(fā),讓開(kāi)發(fā)者感知不到網(wǎng)絡(luò)通信細(xì)節(jié)。所有遠(yuǎn)程調(diào)用,都像調(diào)用本地方法一樣完成2023-02-02
關(guān)于Spring Bean實(shí)例過(guò)程中使用反射和遞歸處理的Bean屬性填充問(wèn)題
本文帶領(lǐng)大家一起學(xué)習(xí)下在Spring Bean實(shí)例過(guò)程中如何使用反射和遞歸處理的Bean屬性填充,需要在類 AbstractAutowireCapableBeanFactory 的 createBean 方法中添加補(bǔ)全屬性方法,具體操作方法跟隨小編一起學(xué)習(xí)下吧2021-06-06
SpringBoot2.x 集成騰訊云短信的詳細(xì)流程
本文主要對(duì)SpringBoot2.x集成騰訊云短信進(jìn)行簡(jiǎn)單總結(jié),其中SpringBoot使用的2.4.5版本,本文通過(guò)業(yè)務(wù)流程圖實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-06-06

