linux定时发送命令 定时命令 linux( 三 )


实例14:一月一号的4点重启smb
0 4 1 jan * /etc/init.d/smb restart
实例15:每小时执行/etc/cron.hourly目录内的脚本
01 * * * * root run-parts /etc/cron.hourly
run-parts这个参数了 , 如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是目录名了 。
目标:每分钟查看一下ganglia的状态,并保存到/tmp/log/ganglia目录 。
1、创建/tmp/log/ganglia目录
sudo mkdir -p /tmp/log/ganglia
sudo chmod a+w /tmp/log/ganglia
2、编辑crontab
crontab -e,选择编辑器为vim
3、在crontab文件中添加一行
4、查看crontab任务
crontab -l ,看到任务已经添加成功 。
5、等待了五分钟,发现/tmp/log/ganglia目录下啥也没有 。
sudo service cron status  , 状态正常 。
sudo /etc/init.d/cron restart  , 重启cron试试 。
又等待了五分钟,发现/tmp/log/ganglia目录下依然空空 。
莫非是因为pssh没有使用绝对路径? whereis pssh,找到pssh路径为 /usr/lib/pssh ,修改crontab为:
然而,并没有用 。
还是查看下crontab日志吧!
以下主要参考 Ubuntu下用crontab 部署定时任务。
1、编辑50-default.conf
sudo vim /etc/rsyslog.d/50-default.conf
2、把cron前的井号去掉,也就是修改为:
3、重启rsyslog服务
sudo service rsyslog restart
4、重启crontab服务
sudo service cron restart
5、查看crontab日志
less /var/log/cron.log
果然发现了问题:
也就是说,命令确实按时执行了,只不过没有执行完 , 被百分号截断了,导致log文件没有正常生成!
修改crontab为:
终于,log文件成功生成,nice!但是,文件内容是空的!因为,/usr/lib/pssh 是一个目录,不是pssh命令!真正的pssh命令是parallel-ssh , 找到它的位置为 /usr/bin/parallel-ssh ,修改crontab:
至此,问题圆满解决 。
实际使用的时候,一天获取一次ganglia的状态就够了,所以crontab改成:
以上,每天执行一次定时任务 , 抓取ganglia的运行状态保存到日志文件中 。紧接着,我们的目标是使用脚本检查当天的日志文件,如果发现ganglia运行异常 , 则产生一个错误日志 。
1、假设日志文件ganglia-20180524.log的内容为:
2、参考 grep命令最经常使用的功能总结 ,编写脚本checkganglia.sh
3、执行
chmod a+x checkganglia.sh
./checkganglia.sh
如果所有客户机的ganglia运行正常,就会输出All services are runing! 。如果有的客户机ganglia进程不存在 , 则会在/tmp/log/ganglia/目录下生成当天的错误日志 。
4、设置定时运行
因为日志的检查工作要在日志生成之后,所以时间上延后十分钟 。
上面的脚本 , 还有很多要改进的地方 。比如有的客户机宕机了,上面的脚本检查不出来 。比如有的客户机ganglia服务没有启动,那么具体是哪几台?针对这两个问题,下面进行改进 。假设已经知道客户机的数量为10 。
参考 csplit命令,checkganglia.sh脚本修改为:
以上脚本,实现了当客户机数量不为10的时候,进行报错;当客户机ganglia服务没有启动时,进行报错 , 并且筛选出所有没有启动ganglia的客户机 。
本文中,我们先学习了crontab的基础知识和基本用法 。然后通过监控ganglia这一个应用场景来具体学习crontab的详细使用方法,包括查看cron日志的方法,crontab中命令转义的方法,定时执行脚本的方法,以及审阅日志脚本的编写和进阶 。
至此,还不够完美,因为我们需要每天登录管理机查看有没有错误日志 。下一篇 Linux设置邮件提醒 中 , 我们将会研究linux设置邮件提醒的方法 。审阅完日志后,如果脚本能够给我们发送一封邮件 , 告知我们审阅的结果,那么我们就不必再每天查看错误日志 。

推荐阅读