linux 系统进程监控 方法 收集
https://www.jianshu.com/p/3ca61b47149a
stdbuf
supervisor
至于类似的工具,node 又 pm2。 新版的 Linux 普遍支持 systemd 也挺好用的
systemd 就行,系统自带+功能完备
monit,轻量简洁
感觉 systemd 足够了
同 systemd, 不过现在跑在 docker 里的多,大多 restart=always 解决了
runit
、
目的: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
#! /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