国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Linux Shell > 正文

shell腳本實現服務器進程監控的方法

2020-07-27 18:48:45
字體:
來源:轉載
供稿:網友
  • 寫作背景:

  項目是基于java、weblogic及timer的處理模式,每次服務部署之后timer的整體狀態是一個盲區,因為100多個進程,是否有啟動遺漏或者啟動重復的,想做到一目了然是件困難的事情。所以我考慮用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 >lsprocess_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 #停復發NASextapp.tftonas.PutTfToNas 10 2extapp.tftonas.PutTfToNas 11 2extapp.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:00127.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/shpath=/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" #主機IPcurrenttime=`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_TIMERfields terminated by '/n'-- Create tablecreate table T_MONITOR_TIMER(  info VARCHAR2(1000))sqlldr userid=用戶名/密碼@sid control=/interface/contabfile/monitor_time/conl.ctl log=/interface/contabfile/monitor_time/conl.log

總結

以上所述是小編給大家介紹的shell腳本實現服務器進程監控的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 桐乡市| 宁南县| 沁源县| 望城县| 饶河县| 德令哈市| 苏尼特左旗| 亚东县| 岗巴县| 竹溪县| 沂水县| 汕尾市| 习水县| 淮北市| 霍城县| 南丹县| 沙河市| 舟山市| 老河口市| 白沙| 罗田县| 米脂县| 玉门市| 女性| 开原市| 南开区| 葵青区| 亚东县| 泰安市| 包头市| 广安市| 阳新县| 台前县| 东兰县| 西藏| 桂林市| 安乡县| 诸城市| 无棣县| 博客| 琼结县|