針對Linux上Java程式運行腳本的Log信息記錄操作人員記錄以及成功運行判斷

来源:https://www.cnblogs.com/heicaijun/archive/2020/04/27/12784671.html
-Advertisement-
Play Games

使用該教程,能直觀地看到java啟動腳本是否啟動/關閉成功 能讓自己的啟動時間日期都記錄在Log中 能記錄有哪些人登陸了該伺服器操作了啟動關閉腳本(記錄IP地址) ...


簡介與優點

使用該教程,能直觀地看到java啟動腳本是否啟動/關閉成功
能讓自己的啟動時間日期都記錄在Log中
能記錄有哪些人登陸了該伺服器操作了啟動關閉腳本(記錄IP地址)

使用說明

在原有的啟動和關閉腳本底下分別加入以下代碼

# 在啟動腳本末尾添加這個
source /home/root/start4Log.sh
# 在關閉腳本末尾添加這個
source /home/root/stop4Log.sh

start4Log.sh腳本

下載地址在start4Log腳本中,可以直觀看到程式是否啟動成功,並將啟動過程記錄在log日誌中

# Log記錄路徑
FWlog_dir=/home/p4fdc/PeakPerformance/FWlog/FWHistory.log

echo "============================" >> ${FWlog_dir}
echo "[start${FID}.sh]" >> ${FWlog_dir}
date -d "today" +"%Y-%m-%d-%H-%M-%S" >> ${FWlog_dir}
# 輸出當前伺服器已登錄的用戶與IP到Log中
who >> ${FWlog_dir}
ps -ef | grep java | grep $FID
# 這裡是對對應的$FID java程式判斷,查詢是否存在這樣的FID的java程式
if [ $? -eq 0 ] ;then
    # 如果上面命令運行成功,也即對應的程式啟動好了則執行下麵的命令
    # 這裡的echo -e是輸出帶格式的字元串。\33[42;37m ????? \033[0m 所包裹的文字將顯示綠底白字
    echo -e "\033[42;37m Start ${FID} Successfully! \033[0m"
    echo "Start ${FID} Successfully!" >> ${FWlog_dir}
    ps -ef | grep java | grep $FID >> ${FWlog_dir}
else
    # 如果上面命令運行失敗,也即對應的程式未啟動好了則執行下麵的命令
    # 這裡的echo -e是輸出帶格式的字元串。\33[41;37m ????? \033[0m 所包裹的文字將顯示紅底白字
    echo -e "\033[41;37m Start ${FID} Failured! \033[0m"
    echo "Start ${FID} Failured!" >> ${FWlog_dir}
fi
echo "============================" >> ${FWlog_dir}

stop4Log.sh

下載地址在stop腳本中可以進行傳參,諸如傳遞一個-f的參數使用 ./stopTestJava.sh -f,則在無法kill的時候使用kill -9強制kill。以下為具體代碼

# 先等待2s,然後再判斷該Java程式是否成功關閉(因為關閉有時延)
sleep 2
FWlog_dir=/home/p4fdc/PeakPerformance/FWlog/FWHistory.log
echo "============================" >> ${FWlog_dir}
echo "[stop$FID.sh] : " >> ${FWlog_dir}
date -d "today" +"%Y-%m-%d-%H-%M-%S" >> ${FWlog_dir}
# 輸出當前伺服器已登錄的用戶與IP到Log中
who >> ${FWlog_dir}
ps -ef | grep java | grep $FID
if [ $? -eq 0 ] ;then
    # 如果上面命令運行成功,也即對應的程式關閉了則執行下麵的命令
    # 這裡的echo -e是輸出帶格式的字元串。\33[41;37m ????? \033[0m 所包裹的文字將顯示紅底白字
    echo -e "\033[41;37m Stop ${FID} Failured! \033[0m"
    echo "Stop ${FID} Failured!" >> ${FWlog_dir}
    ps -ef | grep java | grep $FID >> ${FWlog_dir}  
    # 判斷是否被傳參
    if [[ -n "$1"  ]]; then
    	# 如果含有第一個參數則直接強制kill
    	ps -ef | grep java | grep $FID | grep java | kill -9 `awk '{print $2}'`
		ps -ef | grep java | grep $FID
		if [ $? -eq 0 ] ;then
		    echo -e "\033[41;37m Force Stop ${FID} Still Failured!You need to check manually.\033[0m"
		    echo "Force Stop ${FID} Failured!" >> ${FWlog_dir}
		    ps -ef | grep java | grep $FID >> ${FWlog_dir}
		else
		    # 這裡的echo -e是輸出帶格式的字元串。\33[42;37m ????? \033[0m 所包裹的文字將顯示綠底白字
		    echo -e "\033[42;37m Force Stop ${FID} Successfully! \033[0m"
		    echo "Force Stop ${FID} Successfully!" >> ${FWlog_dir}
		fi
    else
    	# 如果沒有第一個參數則詢問用戶是否強制刪除
    	read -p "Want to Force Kill the process?[y/n]" choice
		case $choice in
		    [yY][eE][sS]|[yY])
	    		ps -ef | grep java | grep $FID | grep java | kill -9 `awk '{print $2}'`
	    		ps -ef | grep java | grep $FID
	    		if [ $? -eq 0 ] ;then
	    			echo -e "\033[41;37m Force Stop ${FID} Still Failured!You need to check manually.\033[0m"
				    echo "Force Stop ${FID} Failured!" >> ${FWlog_dir}
				    ps -ef | grep java | grep $FID >> ${FWlog_dir}
				else
				    echo -e "\033[42;37m Force Stop ${FID} Successfully! \033[0m"
				    echo "Force Stop ${FID} Successfully!" >> ${FWlog_dir}
				fi
				;;
			[nN][oO]|[nN])
				echo -e "\033[41;37m You Need To Check manually!\033[0m "
				echo "Not Choose Force Stop!" >> ${FWlog_dir}
				;;

		    *)
				echo "Invalid input..."
				;;
		esac
    fi

else

    echo -e "\033[42;37m Stop ${FID} Successfully! \033[0m"
    echo "Stop ${FID} Successfully!" >> ${FWlog_dir}

fi
echo "============================" >> ${FWlog_dir}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 回到目錄 我們在前面的BJT直流分析章節,還講過一種“集電極反饋偏置”電路,它也是共射放大電路的一種。這種電路在集電極和基級之間增加了一個反饋電阻,分析難度有所增加,故這裡單獨用一小節進行分析。 1. 基本分析 下麵是一個基本的集電極反饋電路: 圖4-08.01 將上圖中的BJT晶體管替換成re等效 ...
  • Linux系統進程的5種狀態: R(代表當前正在為用戶提供服務的進程); A,sleeping(等待為用戶提供服務的進程); D(不可中斷,雖然當前是為客戶提供服務 但程式出現問題 不能夠中斷) Z,zombie(僵屍進程/僵死進程,當前沒有為客戶提供服務,並且他會一 直消耗你系統的資源) T(代表 ...
  • 文件功能 編輯 ├—WINDOWS │ ├—system32(存放Windows的系統文件和硬體驅動程式) │ │ ├—config(用戶配置信息和密碼信息) │ │ │ └—systemprofile(系統配置信息,用於恢復系統) │ │ ├—drivers(用來存放硬體驅動文件,不建議刪除) │ ...
  • node-gyp rebuildgyp ERR! configure error gyp ERR! stack Error: EACCES: permission denied, mkdir '/usr/local/lib/node_modules/@vue/cli/node_modules/fse... ...
  • 使用該腳本能自行判斷系統記憶體使用情況是否超出設定百分比 能在超出預警值時執行重啟程式的操作 能記錄重啟過程,並將具體LOG郵件發送給指定收信人 可以設定Crontab排程,達成每隔一段時間運行一次 ...
  • Exception in thread "main" java.lang.BootstrapMethodError: java.lang.NoClassDefFoundError: com/google/inject/Stage at org.testng.internal.Configuratio ...
  • 1、PGD: Page Global Directory Linux系統中每個進程對應用戶空間的pgd是不一樣的,但是linux內核 的pgd是一樣的。當創建一個新的進程時,都要為新進程創建一個新的頁面目錄PGD,並從內核的頁面目錄swapper_pg_dir中複製內核區間頁面目錄項至新建進程頁面目 ...
  • When you reinstall win10 system, the VMware dosen't work. The error is shown below: Solution: Disable Device Guard and Hyper-V (1) Disable the group p ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...