虽然已经从事运维两三年了。 但是今天写的计划任务没有执行,排除了下, 这里整理下,方便后期查看。

排除思路

1. 确保crond服务是开机自启和当前是启动的。

# centos
systemctl status crond
systemctl start crond # centos ,
service crond status
chkconfig crond on

2. 检查mail邮件里面关于该计划任务的错误信息。

mail 

这里借用下网络上面的图过来下,

这个情况,一般这些环境配置在profile文件中的, 可以在脚本中source下这个文件, 让其生效,或者把对应的配置写到脚本里面来。

source /etc/profile

3. 脚本里面的命令程序没有在PATH里面。

脚本里面执行的命令,没有在计划任务执行的环境变量里面有, 需要添加进path或者命令写全路径。

# 在可以执行的终端内获取所有PATH, 写入脚本中
echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/local/php/bin:/usr/local/docker/bin:/usr/local/java/jdk1..0_191/bin:/usr/local/java/jdk1..0_191/jre/bin:/usr/local/flume/bin:/usr/local/go/bin:/usr/local/go/bin:/root/bin #在执行脚本中加入如下类似行 PATH=/usr/local/bin:$PATH

4. 使用bash替换

使用crontab -e编辑的计划配置行中, 命令是有限制的, 重定向和特殊符号是不支持的, 这些是bash提供的,可以使用如下方式配置。

# add by zhaojiedi 2019.08.
* * * * bash /usr/local/bin/backup_k8s.sh

5. 封装下计划任务脚本行

我们在计划任务行,写的命令如果长并且带有一些date命令等, 建议把这些命令写入到一个新的文件里面去, 计划任务命令行写这个新的文件作为命令执行。

# 原来计划任务行
* * * * cd /home/barry/top800/top10/top10_fruits/ && ./top10_all.sh # 改写后的
echo "cd /home/barry/top800/top10/top10_fruits/ && ./top10_all.sh" > /usr/local/bin/top10.sh
* * * * * bash /usr/local/bin/top10.sh

最后放一个完整点的计划任务脚本

#!/bin/bash
source /etc/profile
PATH=/usr/local/bin:$PATH
base_dir=/alidata/k8s_backup
dt=$(date "+%F/%T")
cmd_history_file="/usr/local/limikeji/bin/cmd_history.txt" # 先处理有命名空间的
kubectl api-resources |grep true |awk 'BEGIN {OFS=" "; FIELDWIDTHS="34 13 31 13 50"}{if (NR >1)print $5,$1,$4,$3}' |while read kind name has_namespace group ; do
#echo "$kind $name $has_namespace $group"
api_path="$kind"
cmd="kubectl get $api_path --all-namespaces -ocustom-columns=name:.metadata.name,namespace:.metadata.namespace"
$cmd | awk '{if(NR>1)print $0}' |while read record_name ns ; do
file="$base_dir/$dt/$ns/$api_path/${record_name}.yml"
mkdir -pv $(dirname $file)
cmd="kubectl -n $ns get $api_path/$record_name -oyaml "
echo $cmd >>$dt_$cmd_history_file
$cmd > $file
done
done # 后处理无命名空间的
kubectl api-resources |grep false |awk 'BEGIN {OFS=" "; FIELDWIDTHS="34 13 31 13 50"}{if (NR >1)print $5,$1,$4,$3}' |while read kind name has_namespace group ; do
#echo "$kind $name $has_namespace $group"
api_path="$kind"
cmd="kubectl get $api_path -ocustom-columns=name:.metadata.name"
$cmd | awk '{if(NR>1)print $0}' |while read record_name ; do
file="$base_dir/$dt/NONENAMESPACE/$api_path/${record_name}.yml"
mkdir -pv $(dirname $file)
cmd="kubectl get $api_path/$record_name -oyaml "
echo $cmd >>$dt_$cmd_history_file
$cmd > $file
done
done

crontab定时任务不执行,单独运行sh生效的更多相关文章

  1. crontab定时任务不执行的原因

    1.重启crontab若是遇见"You (cloudlogin) are not allowed to use this program (crontab)                 ...

  2. linux crontab定时任务不执行

    如crontab 没有成功,检测crontab 服务是否启动, /etc/init.d/crond status 查看crond状态 /etc/init.d/crond restart 重启crond ...

  3. 如何查看crontab定时任务是否执行过 查看记录

    命令的模式像下面这个: grep "script.php" /path/file.ext. 比如,下面的命令就是从/var/log/cron.log 检测cron任务是否有执行 c ...

  4. 【转】crontab定时任务中文乱码问题

    转载:http://blog.163.com/rettar@126/blog/static/1216503422012135511740/ 手动执行都很正常的的脚步,添加到定时任务中一直执行失败,日志 ...

  5. Crontab无法自动执行,直接运行脚本却能执行

    Crontab无法自动执行,直接运行脚本却能执行 http://bbs.chinaunix.net/thread-1926428-1-1.html crontab -e crontab内容为* * * ...

  6. Linux命令之Crontab定时任务,利用Crontab定时执行spark任务

    Linux命令之Crontab定时任务,利用Crontab定时执行spark任务 一.Linux命令之Crontab定时任务 1.1 常见Crontab任务 1.1.1 安装crontab 1.1.2 ...

  7. 如何让linux定时任务crontab按秒执行

    如何让linux定时任务crontab按秒执行? linux定时任务crontab最小执行时间单位为分钟如果想以秒为单位执行,应该如何设置呢?思路 正常情况是在crontab中直接定义要执行的任务,现 ...

  8. scrapy使用crontab定时任务不能自动执行的调试

    在用crontab进行定时任务时,发现任务并没有执行.而手动bash yourshell.sh时可以正常的执行程序.以下是个人的解决流程. 一.将错误打印打out.log */10 * * * * b ...

  9. 对于crontab定时任务不能自动执行的总结

    最近遇到了一些sh不能在crontab定时任务中自动执行的问题 期间由于不太了解,故走了一点弯路,现在总结下来可能第一次 进行设置遇到的问题.以绝后患!我所用过的操作系统为HP-unix&li ...

随机推荐

  1. HTML 超链接返回上一级

    参考:http://blog.csdn.net/huanongjingchao/article/details/39587663 超链实现返回刚刚访问的网页: <a href="#&q ...

  2. 虚拟化原理到K8s实践经验路线总结

    以下这些内容均为自行学习总结的内容,很多内容没有写概括介绍,看起来可能会有些突兀,但并不影响整体性,我自己的学习经验告诉我,这些内容还仅仅是最精简的核心部分,周边还有很多可扩展内容,主要是操作系统生态 ...

  3. Java 并发系列之一:java 并发体系

    1.  java 并发机制的底层原理实现 1.1 volatile 1.2 synchronized 1.3 原子操作 2. java 内存模型(JMM) 3. java并发基础线程 4. java ...

  4. 读《PMI 分析手册》

    目录 读<PMI 分析手册> 官方 PMI 基本概况 官方制造业 PMI 官方非制造业 PMI 综合 PMI 产出指数 PMI 分析框架 PMI 与经济周期 官方 PMI 分析 参考研报 ...

  5. Apache Kafka - How to Load Test with JMeter

    In this article, we are going to look at how to load test Apache Kafka, a distributed streaming plat ...

  6. 快速获取更丰富的Sitecore体验数据库

    无论您是否立即使用Sitecore的营销功能,我们强烈建议您执行这三项任务,以使您的数据收集更加丰富,并为您以后的决策留下良好的位置. Sitecore的体验数据库,即xDB,是Sitecore营销平 ...

  7. 算法:array1和array2地址值相同,都指向堆空间的唯一的一个数组实体(不是数组的复制)

    package com.atguigu; public class fuzhi { public static void main(String[] args) { int[] array1=new ...

  8. c++ 二维数组定义 二维数组首地址查询

    #include <iostream> using namespace std; int main() { ][] = { {,,}, {,,} }; cout << &quo ...

  9. PHP 将字符串中的数字转化为数组

    $str ='现在是2019年11月18日下午17点25分';$result='';$arr=[];for($i=0;$i<strlen($str);$i++){ if(is_numeric($ ...

  10. CentOS7安装Node_exporter(二进制)

    一.概述 Node_exporter是可以在* Nix和Linux系统上运行的计算机度量标准的导出器.Node_exporter 主要用于暴露 metrics 给 Prometheus,其中 metr ...