Shell腳本管理Java應(yīng)用程序的高效方法
腳本功能概述
本腳本提供以下主要功能:
- 檢查 JAR 包的運(yùn)行狀態(tài)
- 啟動(dòng)尚未運(yùn)行的 JAR 包
- 停止所有運(yùn)行中的 JAR 包
- 刪除 10 天之前的舊日志,并壓縮近期日志
詳細(xì)代碼講解
以下是腳本的主要部分,我們將逐段分析其實(shí)現(xiàn)邏輯。
創(chuàng)建日志目錄:
# 創(chuàng)建日志目錄 [ ! -d "./logs" ] && mkdir ./logs
此部分確保在腳本運(yùn)行時(shí)創(chuàng)建一個(gè)日志目錄,以便存儲(chǔ)后續(xù)生成的日志文件。
檢查進(jìn)程狀態(tài):
check_status() {
for filename in $filenames; do
pid=$(ps -ef | grep $filename | grep -v grep | awk '{print $2}')
if [ -z "$pid" ]; then
echo "$filename: 該服務(wù)未啟動(dòng)"
else
echo "$filename: 該服務(wù)正在運(yùn)行 (PID為: $pid)"
fi
done
}該函數(shù)循環(huán)遍歷當(dāng)前目錄下的所有 JAR 包,使用
ps命令檢查它們的運(yùn)行狀態(tài)。如果沒(méi)有找到相應(yīng)的 PID,則表示服務(wù)未啟動(dòng)。日志清理與壓縮:
# 刪除10天之前的日志文件
delete_old_logs() {
find ./logs -type f -name "*.log" -mtime +10 -exec rm {} \;
echo "已刪除10天之前的日志文件"
}
# 壓縮10天內(nèi)的老日志
compress_old_logs() {
find ./logs -type f -name "*.log" -mtime -10 -exec gzip {} \;
echo "已壓縮10天內(nèi)的老日志文件"
}這兩部分負(fù)責(zé)清理和壓縮日志文件,確保日志目錄不會(huì)占用過(guò)多空間,保持整潔。
停止進(jìn)程:
stop_all() {
for filename in $filenames; do
echo -e "\n------------------------------------------------------"
echo "嘗試優(yōu)雅停止 $filename 進(jìn)程"
ps -ef | grep $filename | grep -v grep | awk '{print $2}' | xargs --no-run-if-empty kill
sleep 3
echo "檢查是否有未終止的 $filename 進(jìn)程,強(qiáng)制結(jié)束"
ps -ef | grep java | grep $filename | grep -v grep | awk '{print $2}' | xargs -r kill -9
echo "$filename 程序已經(jīng)停止"
done
}stop_all函數(shù)嘗試優(yōu)雅地停止所有進(jìn)程,如果未能成功,則強(qiáng)制結(jié)束它們,確保所有服務(wù)都已停止。腳本參數(shù)處理:
case "$1" in
status)
check_status
;;
free)
for filename in $filenames; do
...
done
;;
stop)
stop_all
;;
*)
...
;;
esac此部分根據(jù)用戶輸入的參數(shù)執(zhí)行不同的操作,如查看狀態(tài)、啟動(dòng)或停止服務(wù)。
使用示例
要使用該腳本,可以在終端中運(yùn)行以下命令:
- 重啟所有JAR包:
./your_script.sh - 查看 JAR 包狀態(tài):
./your_script.sh status - 啟動(dòng)未運(yùn)行的 JAR 包:
./your_script.sh free - 停止所有 JAR 包:
./your_script.sh stop
注意事項(xiàng)
在運(yùn)行腳本之前,請(qǐng)確保您擁有足夠的權(quán)限,并檢查腳本中的路徑設(shè)置,避免權(quán)限或路徑錯(cuò)誤導(dǎo)致的運(yùn)行失敗。
總結(jié)
通過(guò)這個(gè)簡(jiǎn)單的 Shell 腳本,您可以高效地管理 Java 應(yīng)用程序的運(yùn)行狀態(tài),確保日志文件的整潔。希望您能根據(jù)自己的需求進(jìn)行修改和擴(kuò)展,讓腳本更符合您的工作流程。
附錄完整代碼
完整代碼:
#!/bin/bash
# 創(chuàng)建日志目錄
[ ! -d "./logs" ] && mkdir ./logs
# 獲取當(dāng)前目錄下所有的 jar 文件名
filenames=$(ls *.jar)
echo "獲取當(dāng)前目錄下所有的 jar 包文件名"
# 定義函數(shù):檢查進(jìn)程狀態(tài)
check_status() {
for filename in $filenames; do
pid=$(ps -ef | grep $filename | grep -v grep | awk '{print $2}')
if [ -z "$pid" ]; then
echo "$filename: 該服務(wù)未啟動(dòng)"
else
echo "$filename: 該服務(wù)正在運(yùn)行 (PID為: $pid)"
fi
done
}
# 刪除10天之前的日志文件
delete_old_logs() {
find ./logs -type f -name "*.log" -mtime +10 -exec rm {} \;
echo "已刪除10天之前的日志文件"
}
# 壓縮10天內(nèi)的老日志
compress_old_logs() {
find ./logs -type f -name "*.log" -mtime -10 -exec gzip {} \;
echo "已壓縮10天內(nèi)的老日志文件"
}
# 定義函數(shù):停止所有進(jìn)程
stop_all() {
for filename in $filenames; do
echo -e "\n------------------------------------------------------"
echo "嘗試優(yōu)雅停止 $filename 進(jìn)程"
ps -ef | grep $filename | grep -v grep | awk '{print $2}' | xargs --no-run-if-empty kill
sleep 3
echo "檢查是否有未終止的 $filename 進(jìn)程,強(qiáng)制結(jié)束"
ps -ef | grep java | grep $filename | grep -v grep | awk '{print $2}' | xargs -r kill -9
echo "$filename 程序已經(jīng)停止"
done
}
# 判斷腳本參數(shù)
case "$1" in
status)
echo "后綴status 查看當(dāng)前文件夾下所有jar運(yùn)行狀態(tài)"
check_status
;;
free)
echo "后綴free 啟動(dòng)尚未啟動(dòng)的 jar 包"
for filename in $filenames; do
pid=$(ps -ef | grep $filename | grep -v grep | awk '{print $2}')
if [ -z "$pid" ]; then
logname=$(basename $filename .jar)
timestamp=$(date +"%Y%m%d_%H%M%S")
echo "開(kāi)始啟動(dòng) $filename"
nohup java -server -Xms1024m -Xmx1024m -XX:MetaspaceSize=200m -jar $filename >> ./logs/outlog_${logname}_$timestamp.log 2>&1 &
echo "啟動(dòng) $filename 結(jié)束,日志輸出到 ./logs/outlog_${logname}_$timestamp.log"
else
echo "$filename: 已在運(yùn)行,跳過(guò)啟動(dòng)"
fi
done
;;
stop)
stop_all
;;
*)
echo "進(jìn)行默認(rèn)選項(xiàng),重新啟動(dòng)所有 jar 包(可通過(guò)status后綴查看狀態(tài)、free啟動(dòng)未運(yùn)行jar服務(wù),stop停止當(dāng)前目錄下所有jar包服務(wù))"
stop_all
# 執(zhí)行日志清理和壓縮
delete_old_logs
compress_old_logs
for filename in $filenames; do
sleep 2
logname=$(basename $filename .jar)
timestamp=$(date +"%Y%m%d_%H%M%S")
echo "開(kāi)始啟動(dòng) $filename"
nohup java -server -Xms1024m -Xmx1024m -XX:MetaspaceSize=200m -jar $filename >> ./logs/outlog_${logname}_$timestamp.log 2>&1 &
sleep 2
echo "啟動(dòng) $filename 結(jié)束,日志輸出到 ./logs/outlog_${logname}_$timestamp.log"
done
;;
esac


以上就是Shell腳本管理Java應(yīng)用程序的高效方法的詳細(xì)內(nèi)容,更多關(guān)于Shell腳本管理Java程序的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
SpringBoot的application.yml不生效問(wèn)題及解決
這篇文章主要介紹了SpringBoot的application.yml不生效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
jdbc實(shí)現(xiàn)用戶注冊(cè)功能代碼示例
這篇文章主要介紹了jdbc實(shí)現(xiàn)用戶注冊(cè)功能,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
基于@RequestParam注解之Spring MVC參數(shù)綁定的利器
這篇文章主要介紹了基于@RequestParam注解之Spring MVC參數(shù)綁定的利器,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
MyBatisPlus 主鍵策略的實(shí)現(xiàn)(4種)
MyBatis Plus 集成了多種主鍵策略,幫助用戶快速生成主鍵,本文主要介紹了MyBatisPlus主鍵策略的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
springboot aspect通過(guò)@annotation進(jìn)行攔截的實(shí)例代碼詳解
這篇文章主要介紹了springboot aspect通過(guò)@annotation進(jìn)行攔截的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
通過(guò)idea創(chuàng)建Spring Boot項(xiàng)目并配置啟動(dòng)過(guò)程圖解
這篇文章主要介紹了通過(guò)idea創(chuàng)建Spring Boot項(xiàng)目并配置啟動(dòng)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11

