欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Shell腳本管理Java應(yīng)用程序的高效方法

 更新時(shí)間:2024年09月29日 10:15:59   作者:不掉頭發(fā)的阿水  
在軟件開(kāi)發(fā)中,管理和監(jiān)控 Java 應(yīng)用程序的運(yùn)行狀態(tài)變得愈加重要,本文將分享一個(gè)自用的簡(jiǎn)單但高效的 Shell 腳本,幫助輕松管理 JAR 包的啟動(dò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)題及解決

    這篇文章主要介紹了SpringBoot的application.yml不生效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • java中計(jì)算集合的交差并集示例代碼

    java中計(jì)算集合的交差并集示例代碼

    今天突然想Java如何計(jì)算集合的交差并集,主要是看Python語(yǔ)言的時(shí)候想起來(lái)的。下面這篇文章主要給大家介紹了關(guān)于java中計(jì)算集合的交差并集的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-08-08
  • jdbc實(shí)現(xiàn)用戶注冊(cè)功能代碼示例

    jdbc實(shí)現(xiàn)用戶注冊(cè)功能代碼示例

    這篇文章主要介紹了jdbc實(shí)現(xiàn)用戶注冊(cè)功能,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • java編寫簡(jiǎn)易貪吃蛇游戲

    java編寫簡(jiǎn)易貪吃蛇游戲

    這篇文章主要為大家詳細(xì)介紹了java編寫簡(jiǎn)易貪吃蛇游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 基于@RequestParam注解之Spring MVC參數(shù)綁定的利器

    基于@RequestParam注解之Spring MVC參數(shù)綁定的利器

    這篇文章主要介紹了基于@RequestParam注解之Spring MVC參數(shù)綁定的利器,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-03-03
  • SpringBoot登錄用戶權(quán)限攔截器

    SpringBoot登錄用戶權(quán)限攔截器

    這篇文章主要介紹了SpringBoot登錄用戶權(quán)限攔截器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Spring注解之@Import注解的使用和源碼分析

    Spring注解之@Import注解的使用和源碼分析

    今天主要介紹Spring @Import注解,在Spring中@Import使用得比較頻繁,它得作用是導(dǎo)入bean,具體的導(dǎo)入方式有多種,特別在SpringBoot項(xiàng)目中,很多地方都使用到了@Import注解,感興趣的小伙伴可以參考閱讀
    2023-04-04
  • MyBatisPlus 主鍵策略的實(shí)現(xiàn)(4種)

    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)行攔截的實(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ò)idea創(chuàng)建Spring Boot項(xiàng)目并配置啟動(dòng)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論