您好,登錄后才能下訂單哦!
使用shell腳本怎么實現服務器進程監控?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
程序說明:
1)通過將系統定義的進程(timer)配置到配置文件process_signal.config中
2)將服務器當前所有的java進程存儲到process_current.txt中
3)逐行讀取process_signal.config中的進程,到process_current.txt中進行匹配
4)沒有匹配到則為啟動遺漏,存入到process_invalid.txt中,匹配到1次正常(不做處理),匹配到大于1次,則將timer名稱及啟動次數記錄到process_invalid.txt中。
5)通過定時器30分鐘一次執行腳本,使用SQLLOAD將process_invalid.txt加載到數據表中,對數據庫表進行監控。
腳本說明:
1、整體文件結構:
webusr@iomtimer1:/weblogic/script/process_signal >ls process_current.txt process_invalid.txt process_invalid_his.txt process_signal.config process_signal.sh
2、進程配置示例:
webusr@iomtimer1:/weblogic/script/process_signal >cat process_signal.config #停復發NAS extapp.tftonas.PutTfToNas 10 2 extapp.tftonas.PutTfToNas 11 2 extapp.tftonas.PutTfToNas 12 3
3、執行結果記錄:
webusr@iomtimer1:/weblogic/script/process_signal >cat process_invalid.txt 127.0.0.1 process [extapp.leaseroute.PutToLeaseRoute 180] is not exist 2018-04-11 08:29:00 127.0.0.1 process [ DealWorkTaskTimer 3001 ] is repeatRun 2 Times 2018-04-11 17:51:56
4、邏輯匹配入口:
webusr@iomtimer1:/weblogic/script/process_signal >cat process_signal.sh #!/bin/sh path=/weblogic/script/process_signal #腳本路徑 file_config=process_signal.config #配置文件名 file_result=process_invalid.txt #錯誤進程信息 file_tmp=process_current.txt #當前進程信息(全量,臨時) if_get_exist="N" #是否輸出日志(N不輸出,Y輸出) hostip="127.0.0.1" #主機IP currenttime=`date "+%Y-%m-%d %H:%M:%S"` #當前系統時間 #定義方法get_process_signal() get_process_signal(){ # 轉儲上次記錄到歷時,追加 cat /weblogic/script/process_signal/process_invalid.txt >> process_invalid_his.txt #清空錯誤進程信息,當前進程信息 >/weblogic/script/process_signal/process_invalid.txt >/weblogic/script/process_signal/process_current.txt #輸出當前時間并獲取主機上所有java類進程 echo "######################### get ps info time is: " $currenttime " #########################">>/weblogic/script/process_signal/process_current.txt ps -ef|grep java >>/weblogic/script/process_signal/process_current.txt echo "######################### get ps info time is: " $currenttime " #########################">>/weblogic/script/process_signal/process_current.txt #逐條讀取配置文件process_signal.config cat /weblogic/script/process_signal/process_signal.config | while read LINE do # 如果配置文件含有#號,則跳過不處理 if [[ `echo $LINE|cut -c1-1` != "#" ]]; then #如果配置文件記錄在主機進程中存在 if [[ -n `find $path -name $file_tmp | xargs grep -w "$LINE"` ]]; then #開關為Y,輸出到屏幕 if [[ $if_get_exist = "Y" ]]; then echo $hostip " process [" $LINE "] is exist " $currenttime >>/weblogic/script/process_signal/process_invalid.txt fi #配置文件記錄與主機進程匹配 run=`find $path -name $file_tmp | xargs grep -w "$LINE"|wc -l` if (($run>1)); then #打印配置文件中記錄與主機進程匹配數大于1的記錄 echo $hostip " process [" $LINE "] is repeatRun "$run " Times" $currenttime >>/weblogic/script/process_signal/process_invalid.txt fi #如果配置文件記錄在主機進程中不存在 else echo $hostip " process ["$LINE"] is not exist " $currenttime >>/weblogic/script/process_signal/process_invalid.txt fi fi done } #調用方法 get_process_signal #fhs.workflow.EventMonitorMain 4 #find /weblogic/script/process_signal -name process_current.txt | xargs grep -i "fhs.workflow.EventMonitorMain 4" #ps -ef|grep java|grep "fhs.workflow.EventMonitorMain 4"
5、SqlLOAD入庫(含控制文件conl.ctl)
efile92@iomitfdb2:/interface/contabfile/monitor_time >cat conl.ctl load data infile '/interface/contabfile/monitor_time/process_invalid.txt' truncate into table T_MONITOR_TIMER fields terminated by '\n' -- Create table create table T_MONITOR_TIMER ( info VARCHAR2(1000) ) sqlldr userid=用戶名/密碼@sid control=/interface/contabfile/monitor_time/conl.ctl log=/interface/contabfile/monitor_time/conl.log
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。