shell脚本实现服务器进程监控的方法
- 写作背景:
项目是基于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>ls process_current.txtprocess_invalid.txtprocess_invalid_his.txtprocess_signal.configprocess_signal.sh
2、进程配置示例:
webusr@iomtimer1:/weblogic/script/process_signal>catprocess_signal.config #停复发NAS extapp.tftonas.PutTfToNas102 extapp.tftonas.PutTfToNas112 extapp.tftonas.PutTfToNas123
3、执行结果记录:
webusr@iomtimer1:/weblogic/script/process_signal>catprocess_invalid.txt 127.0.0.1process[extapp.leaseroute.PutToLeaseRoute180]isnotexist2018-04-1108:29:00 127.0.0.1process[DealWorkTaskTimer3001]isrepeatRun2Times2018-04-1117:51:56
4、逻辑匹配入口:
webusr@iomtimer1:/weblogic/script/process_signal>catprocess_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"#########################getpsinfotimeis:"$currenttime"#########################">>/weblogic/script/process_signal/process_current.txt ps-ef|grepjava>>/weblogic/script/process_signal/process_current.txt echo"#########################getpsinfotimeis:"$currenttime"#########################">>/weblogic/script/process_signal/process_current.txt #逐条读取配置文件process_signal.config cat/weblogic/script/process_signal/process_signal.config|whilereadLINE do #如果配置文件含有#号,则跳过不处理 if[[`echo$LINE|cut-c1-1`!="#"]];then #如果配置文件记录在主机进程中存在 if[[-n`find$path-name$file_tmp|xargsgrep-w"$LINE"`]];then #开关为Y,输出到屏幕 if[[$if_get_exist="Y"]];then echo$hostip"process["$LINE"]isexist"$currenttime>>/weblogic/script/process_signal/process_invalid.txt fi #配置文件记录与主机进程匹配 run=`find$path-name$file_tmp|xargsgrep-w"$LINE"|wc-l` if(($run>1));then #打印配置文件中记录与主机进程匹配数大于1的记录 echo$hostip"process["$LINE"]isrepeatRun"$run"Times"$currenttime>>/weblogic/script/process_signal/process_invalid.txt fi #如果配置文件记录在主机进程中不存在 else echo$hostip"process["$LINE"]isnotexist"$currenttime>>/weblogic/script/process_signal/process_invalid.txt fi fi done } #调用方法 get_process_signal #fhs.workflow.EventMonitorMain4 #find/weblogic/script/process_signal-nameprocess_current.txt|xargsgrep-i"fhs.workflow.EventMonitorMain4" #ps-ef|grepjava|grep"fhs.workflow.EventMonitorMain4"
5、SqlLOAD入库(含控制文件conl.ctl)
efile92@iomitfdb2:/interface/contabfile/monitor_time>catconl.ctl loaddata infile'/interface/contabfile/monitor_time/process_invalid.txt' truncateintotableT_MONITOR_TIMER fieldsterminatedby'\n' --Createtable createtableT_MONITOR_TIMER ( infoVARCHAR2(1000) ) sqlldruserid=用户名/密码@sidcontrol=/interface/contabfile/monitor_time/conl.ctllog=/interface/contabfile/monitor_time/conl.log
总结
以上所述是小编给大家介绍的shell脚本实现服务器进程监控的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!