crontab小节2则:①crontab运行失败;②shell批量管理crontab

如果你点到这里,希望你能往下看下内容。

crontab运行失败

首先,用crontab一般都是来跑shell脚本的,python相关的暂请绕道= =


排除我遇到的问题的第一种可能::我们来分析下crontab的机制。(每个linux用户都有自己的crontab任务:/var/spool/cron/ 每个用户都是自己名字命名的文件夹。)so,可以这么理解。当我们每个用户用自己的号登陆服务器的时候,每个终端(tty)启动的时候,都会读一次环境变量(/etc/profile),但是crontab跑起来的就不一样了,它不会去读所谓的/etc/profile的,所以,脚本中最好加上source /etc/profile,才能保证这里不会出问题。

然后我来描述下我遇到的问题:

需求:需要监控每台服务器上N多用户中配置文件中的异常。我的服务器环境是禁止root-ssh登录的,需要用admin用户登录,然后suroot。所以当遇到很多台机器的时候,就有一些的局限性。(之前试着写了几次expect,总是绕不过su,写了一会没耐心就停了。我试了另外一种方法第二段写出来。)

经过1在这里,会有很多人发现我饶了很多圈!这点我现在做这个当时已经考虑到了,但是仍然这么走尝试了下:因为root一般情况下不登录。我们对admin放了一个sh的权限,也就是在/etc/sudoer里面给admin负了个可以sh的权限。这里有一点疏忽,后边我会说到。

经过2我写好的脚本是放在本机root跑的,然后把结果放在本机上,然后统一用一台管理机来扫这个文件,然后把结果汇总,进行报警通知。

经过3别的不贴了,写一下我采集的脚本中的1个函数,也就是这里出了问题:

#        /usr/bin/ssh -p 端口 -t admin@$1 "echo 密码 | sudo -S sh -c \"cat /home/zabbix/mysqlcheck/stand2/result\""|sed "s@\[sudo\] password for admin: @@g" > $DIR/biaozhun.txt

经过4细心的大哥们会看到,我这里ssh的时候,起了1个终端t,这里的tman里面的大概解释是这样的:强制配置pseudo-tty. 这可以在远程机器上去执行任意的screen-based方程式。所以这里就可以相当于expect一样echo密码进去了,达到sudo输入密码的效果,然后在进行处理。

结果,我把这个脚本放在crontab里面,2天后才发现他根本没跑。然后经过各种测试,确定了函数里面没运行。但是奇怪的是我命令行调脚本跑的很畅快。。

最后,我把全部错误信息都打了出来,发现提示我没有tty去跑。

解决办法:

1、将zabbix的整个目录都改了权限,然后直接ssh admincat

2、/etc/sudoer中的Defaults requiretty 注释掉。

当然,这种“老套”的监控方式是有很多的弊端的,我也进行了一些别的修改。今天想不全当时遇到的繁琐的问题了,所以整理的有些简单,以后想到了会来补一下。


shell“批量管理”crontab

1、首先来曝下上边提到的安装方法:

函数:

#ssh -p 端口 -t admin@$1 "echo 密码 | sudo -S sh -c \"cd /usr/local/src;wget 'http://sourceforge.net/projects/logcheck/files/latest/download?source=dlp';tar -zvxf logcheck-1.1.2.tar.gz;cd logcheck-1.1.2;make linux;chmod 705 /usr/local/bin/logtail;echo $1>>1111 \""

2、crontab任务,

Crontab添加任务 为crontab -e ,方式为一些前学者提到的“交互式”,反正就是没法用命令行进行修改吧。

于是我这样来写了一下

#!/bin/sh
BASEDIR=/home/zabbix
PROGRAM=$BASEDIR/ccms-errlog/check.sh
DIRCRIPTION="#ccms数据库监控err log check-add by yanzong.chen"
CRONTAB_CMD="*/15 * * * * sh $PROGRAM  &> /dev/null 2>&1 &"
(crontab -l 2>/dev/null | grep -v $PROGRAM;echo $DIRCRIPTION ;echo "$CRONTAB_CMD") | crontab -
COUNT=`crontab -l | grep $PROGRAM | grep -v "grep"|wc -l `
if [ $COUNT -lt 1 ]; then
        echo "fail to add crontab $PROGRAM" >$BASEDIR/erro
fi

删除

#!/bin/sh
BASEDIR=/home/zabbix
PROGRAM=$BASEDIR/ccms-errlog/check.sh
DIRCRIPTION="#ccms数据库监控err log check-add by yanzong.chen"
CRONTAB_CMD="*/15 * * * * sh $PROGRAM  &> /dev/null 2>&1 &"
(crontab -l 2>/dev/null | egrep -v "$PROGRAM|$DIRCRIPTION|$CRONTAB_CMD") | crontab -
COUNT=`crontab -l | grep $PROGRAM | grep -v "grep"|wc -l `
if [ $COUNT -eq 1 ]; then
        echo "fail to del crontab $PROGRAM"
fi

~

你可能感兴趣的:(crontab,crontab运行失败)