linux 系统进程监控 方法 收集

91 篇文章 3 订阅

linux 系统进程监控 方法 收集

https://www.jianshu.com/p/3ca61b47149a

stdbuf

supervisor
至于类似的工具,node 又 pm2。 新版的 Linux 普遍支持 systemd 也挺好用的
systemd 就行,系统自带+功能完备
monit,轻量简洁
感觉 systemd 足够了
同 systemd, 不过现在跑在 docker 里的多,大多 restart=always 解决了
runit

linux 进程监控和自动重启的简单实现

目的:linux 下服务器程序会因为各种原因dump掉,就会影响用户使用,这里提供一个简单的进程监控和重启功能。

实现原理:由定时任务crontab调用脚本,脚本用ps检查进程是否存在,如果不存在则重启并写入日志。

1、crontab修改
https://www.cnblogs.com/fatt/p/4974756.html

在以上各个字段中,还可以使用以下特殊字符:

星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。

逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”

中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”

正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。

https://my.oschina.net/u/3009151/blog/834946

#!/bin/sh
cd /opt/java2/python/
data=./Begin
ps -fe|grep $data |grep -v grep
if [ $? -ne 0 ]
then
echo begin `date '+%Y%m%d %H:%S:%M'`
echo "start process....."
sh /opt/java2/python/start.sh
else
	echo "runing....."
fi


参考2:

#! /bin/sh  
  
host_dir="/opt/ybg/"                                       # 当前用户根目录  
proc_name="java"                                        # 进程名  
file_name="monitor.log"               # 日志文件  
pid=0  
  
proc_num()                                              # 计算进程数  
{  
    num=`ps -ef | grep $proc_name | grep -v grep | wc -l`  
    return $num  
}  
  
proc_id()                                               # 进程号  
{  
    pid=`ps -ef | grep $proc_name | grep -v grep | awk '{print $2}'`  
}  
# 通过curl模拟登录获取http_code,模拟登录参数仅供参考
# 如果只需要判断某页面的状态可使用curl -I -s -w "%{http_code}" -o /dev/null http://www.baidu.com/ 直接获取即可
http_code=`curl -I -s -w "%{http_code}" -o -d "userKey=admin&pass=c9127e832b41a" /dev/null  http://portal.ly-sky.com/login.do?login= | head -n 1 | cut -d$' ' -f2`  

proc_num  
number=$?  
if [[ $number -eq 0 ]]||[[ $http_code -ne 200 ]]          # 判断进程是否存在  
then   
    cd /opt/ybg/URP/bin/
    nohup ./run.sh>../logs/urp.log 2>&1 &    # 重启进程的命令,请相应修改  
    sleep 3                                  #延迟3秒是为了确保进程已正常启动并方便获取pid,否则有可能获取不到pid
	proc_id                                         # 获取新进程号  
    echo $pid, `date` >> $host_dir$file_name      # 将新进程号和重启时间记录  
fi 

nohup 是什么 ?

可以用的脚本

#! /bin/sh


proc_name="test.py"
file_name="./monitor.log"
pid=0

proc_num()
{
    num=`ps -ef | grep $proc_name | grep -v grep | wc -l`
    return $num
}

proc_id()
{
    pid=`ps -ef | grep $proc_name | grep -v grep | awk '{print $2}'`
}


proc_num
number=$?
if [[ $number -eq 0 ]]
then
        python ./test.py &
    sleep 2
        proc_id
    echo $pid, `date` >> $file_name
fi

https://www.cnblogs.com/xuanyuanchen/p/5687762.html

用crontab、crond在嵌入式系统中添加定时任务
在嵌入式系统中,定时任务通过crond和cronttab两个系统命令来联合执行。

其中crond是定时任务的守护进程,系统开始时是没有开启的。crontab主要作用是管理用户的crontab files.

crontab - maintain cron-tab files for individual users
crond - daemon to execute scheduled commands
在编制busybox系统的时候,由于/var路径的容量实在是太小了,没有办法开始寻找其他的路径作为替代。

其中,crond和crontab默认是在 /var/spool/cron/crontabs/目录 执行和查找crontab任务的。

crontab -c /etc/crontabs/ /etc/crontabs/root
#change the default root_crontab_file to /etc/crontabs/root

crond -c /etc/crontabs/
#change crond directory
将上面这段代码加入到/etc/rc.d/rc.local的末尾。

其中root文件是其中针对root用户的cron-tab文件,其内容是:

0 */1 * * * hwclock -s
#每隔1个小时执行一次时钟 同步任务
另外,注意给root文件添加可执行权限。「chmod 777 /etc/crontabs/root」

crontab:是cron和table(表格)的组合。

crond:是cron和daemon(守护进程)的组合。

cron来自于「古希腊文:Χρόνος ,英文:Chronos,中文:时间」。



*/5 * * * * sh /root/modbus_client/monitor_modbus_client.sh
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值