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

相关推荐

  • linux之运维性能命令

    在 Linux 系统中,有许多命令和工具可以帮助运维人员监控系统状态、性能以及定位问题。以下是一些常用的运维相关命令: top: 如前所述,实时显示进程的资源占用情况。 htop: 类似于 top,但提供了一个更为用户友好的界面,支持颜色显示和滚动。 vmstat: 报告有关系统进程、内存、分页、块 IO、陷阱和 CPU 活动的信息。 iostat: 用于监…

    2024年7月3日
    2.0K00
  • 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.7K00
  • 设备 eth0 似乎不存在, 初始化操作将被延迟

    今天将eth0文件编辑好之后,不管是重启network还是重启电脑都没用,一直显示个eth1,我就很纳闷,明明没有eth1这个文件,eth1到底从哪里来的,网上好多方法都试过了还是不行,什么删除/etc/udev/rules.d/70-persistent-net.rules这个文件,然后重启电脑,没用!关闭NetworkManager服务,没用!有的甚至说…

    2023年3月2日
    1.1K00
  • 如何升级vCenter(VCSA)补丁?

    VCSA的升级分为repo源和iso镜像两种方式,由于使用repo源进行升级只支持HTTPS和FTPS协议,需要额外搭建环境,略复杂,本文介绍使用iso镜像方式升级。 一、下载补丁: 1、登录VMware官网下载最新的补丁包:(需要注册VMware会员) 下载地址:https://my.vmware.com/cn/group/vmware/patch#sea…

    2023年2月4日
    1.1K00
  • k8s-重启Pod方法

    kubectl 没有 restart pod 这个命令,主要是由于在 k8s 中pod 的管理属于rs 等控制器,并不需要手动维护,但有时更新了yaml文件后,期望破都能够”重启”重新加载yaml文件,比如修改了configmap 的配置文件后,希望重启pod 加载配置,此时就需要 “重启” Pod。而”重启”…

    2023年10月9日
    1.3K00

发表回复

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

在线咨询: QQ交谈

邮件:712342017@qq.com

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

关注微信