crontab中反引号和$()无效的解决

问题描述

1.增加了一条crontab,删除本月中2天以前的日志

10 02  * * * /bin/find /data/logs/php/$(date  +%Y%m)/ -mtime +2 | xargs rm -rf

 

可是看上面的crontab总是运行失败,然后查/var/log/cron 日志报

Jul 22 02:02:01  localhost CROND[7699]: (root) CMD (/bin/find /data/logs/php/`date +")

显示$(date  +%Y%m) 这个有问题,在终端上运行是没问题的,后来搜索baidu

问题原因:

在crontab中%字符被认为是换行,所以你的命令中有%时,在crontab中要加\转义
比如

30 * * * * date '+%D' >datefile  

是错误的

正确的应该是

30 * * * * date '+\%D' >datefile

 

所以上面正确的crontab是:

10 02  * * * /bin/find /data/logs/php/$(date  +\%Y\%m)/ -mtime +2 | xargs rm -rf

 

扩展

造成crontab无法正常运行的常见原因

 

问题及对应解决方法
【1】脚本的执行权限问题
写好脚本后,要赋予脚本执行权限,避免权限问题

<1>赋予脚本执行权限
chmod +x test1.sh

 

【2】脚本在crontab里的路径问题
<1>查看crontab中,你的脚本的位置是否有错误

注意是否字符错误

查看计划任务:
crontab -l

写入计划任务:
crontab -e

<2>如无错误,查看路径是否错误

在计划任务里要使用全路径

例如:

*/5 * * * * /App/test/test1.sh

<3>修改有问题的字符或路径即可

【3】计划任务的时间设置问题
<1>查看计划任务的时间是否设置的有问题

如果crontab设置的时间错误,会导致无法按原计划时间进行任务

计划任务的5个*号依次代表的含义:
分 时 日 月 周

 

<2>如有问题,修改为正确的时间即可

【4】脚本的头部问题
<1>查看一下你的脚本的头部,查看你为脚本设置的解释器

 

<2>查看当前系统是否包含此解释器或路径是否与脚本头部相同

可以用whereis 查看,例如
whereis sh

<3>如果是脚本的解释器的路径有误,将脚本的头部的路径修改为当前系统的路径即可

【5】脚本的执行命令问题
在Linux系统中,使用crontab执行脚本,由于crontab没有环境变量,它是找不到你使用的命令的,需要使用命令的全路径,才可使用命令

例如:使用python

0 1 * * * /usr/bin/python /App/test/test1.py

【6】环境变量的问题
这个是最常见的问题。
crontab执行计划任务时,它并不会从用户的profile文件中读取环境变量,所以会导致命令执行失败。

<1>让脚本读取环境变量

在你的脚本的开头中添加如下几行,也可读取其他变量文件

#!/bin/bash

source /etc/profile
source ~/.bash_profile

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/7803

(0)
郭靖的头像郭靖
上一篇 2023年3月28日 下午5:22
下一篇 2023年3月29日 下午4:33

相关推荐

  • find命令排除某些目录或文件

    使用-prune开关。例如,如果要排除misc目录,只需将a添加-path ./misc -prune -o到您的find命令中: find . -path ./misc -prune -false -o -name ‘*.txt’ 这是带有多个目录的示例: find . -type d \( -path dir1 -o -path dir2 -o -pat…

    2023年6月16日
    1.4K00
  • 安装linux/Centos系统出现An Unknown Error Has Occurred报错原因和解决方法

    今天在给一个客户重装系统的时候出现: An Unknown Error Has OccurredThis program has encountered an unknown error. You may report the buy below or quit the program. This program has encountered an unk…

    2024年3月25日
    1.6K00
  • IPMItool 控制风扇转速

    近期由于需要测试dell服务器,风扇声音非常的大,通过IPMI页面发现不能设置风扇的转速,所以使用通过IPMItool工具来进行控制 首先进入服务器,安装IPMItool工具 apt install ipmitool 验证是否能够使用 如果不在本机服务器上操作,需要从其他机器上操作,需要勾选IPMI设置,允许通过lan进行操作 获取风扇的速度 首先你要输入下…

    2024年4月12日
    1.7K00
  • 使用jenkins 打包前端私服代码失败的问题

    问题现象: jinekins 流水线在yarn 编译前端私服依赖包的时候,报错,提示 Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). 【emm。。。之前的构建都是好好的,也不知道前端大哥啥时候去封装的前端代码,而且奇怪的是没有放在公共库里。。。。】 Pipeline 流…

    2023年1月31日
    94600
  • Centos7.6安装MySQL(超详细)

    1、查看是否已经安装Mysql rpm -qa | grep mysql 我已经安装过了 如果你查看出来有东西,可以使用下面命令将其删除 rpm -e 文件名 如果提示warning: waiting for transaction lock on /var/lib/rpm/.rpm.lock,则需要执行 2、下载官方Mysql包 wget -i -c ht…

    2022年6月9日
    1.6K00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信