crontab中实现定时任务失效怎么办,什么原因
Admin 2022-07-26 群英技术资讯 596 次浏览
我在crontab
中添加一条定时任务如下,用于每天把旧日志移到指定目录:
0 0 * * * cd /home/vg/odp/log && mv *`date -d "-10 day" "+%Y%m%d"`* archives
然后这个定时任务似乎没有生效。单独执行后面的命令都是成功的没有报错。
crontab
的执行情况,linux都会给对应的用户发邮件,因此可以通过邮件来定位问题。上面的任务在vg用户下,查看对应的邮件 /var/spool/mail/vg
, 找到和出问题的任务相关的内容如下:
From root@MyServer.localdomain Tue May 14 18:00:01 2019 Return-Path: X-Original-To: vg Delivered-To: vg@MyServer.localdomain Received: by MyServer.localdomain (Postfix, from userid 500) id 694075F2AD; Tue, 14 May 2019 18:00:01 +0800 (CST) From: root@MyServer.localdomain (Cron Daemon) To: vg@MyServer.localdomain Subject: Cron cd /home/vg/odp/log && mv *`date -d "-10 day" "+ Content-Type: text/plain; charset=UTF-8 Auto-Submitted: auto-generated X-Cron-Env: X-Cron-Env: X-Cron-Env: X-Cron-Env: X-Cron-Env: X-Cron-Env: Message-Id: Date: Tue, 14 May 2019 18:00:01 +0800 (CST) /bin/sh: -c: line 0: unexpected EOF while looking for matching ``' /bin/sh: -c: line 1: syntax error: unexpected end of file
上面清楚地记录了出错原因:unexpected EOF while looking for matching ``'
看报错得知还没有匹配到`命令就结束了,问题看似奇怪,因为定时任务命令单独拿出来执行是没有问题的,再仔细看邮件内容,Subject那一行:
Subject: Cron cd /home/vg/odp/log && mv *`date -d "-10 day" "+
显示的命令不全,到加号就结束了,%和后面的部分丢失了,结合报错基本可以定位原因,%是crontab里的特殊符号,表示新的一行开始,所以前面的命令就被截断了。
如果crontab执行的命令中包含%需要用\转义,上面的例字改成这样就可以成功执行:
0 0 * * * cd /home/vg/odp/log && mv *`date -d "-10 day" "+\%Y\%m\%d"`* archives
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
不少网友都想知道怎样用scp在 linux 系统之间复制文件?带着这个问题,小编在此整理了相关内容,如果你感兴趣的话千万不要错过了这篇文章。
centos7安装zabbix3.0超详细步骤解析教程
Manjaro linux怎么调鼠标速度?Manjaro系统想要调鼠标速度,该怎么设置鼠标速度呢?下面我们就来看看Manjaro鼠标设置光标速度的技巧,详细请看下文介绍
日志记录中HTTP状态码出现499错误有多种情况,我遇到的一种情况是nginx反代到一个永远打不开的后端,就这样了,日志状态记录是499、发
linux文件的大小能限制;不同的文件系统对文件大小的限制是不同的,例如ext3文件系统最大支持块数是2的32次方,块数的大小可变,能够直接影响到文件系统的大小和文件的大小,而etx3文件系统能够支持的最大文件大小是2TB。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008