美文网首页
2019-04-28定时任务(下)

2019-04-28定时任务(下)

作者: 看见光明才有希望 | 来源:发表于2019-04-28 17:00 被阅读0次

每天晚上12点 打包备份/etc/目录到/tmp下面

14.5.1#第一个里程碑-命令行测试{测试命令是否ok}

[root@oldboyedu59 ~]# 
[root@oldboyedu59 ~]# tar zcf /tmp/etc.tar.gz  /etc/ 
tar: Removing leading `/' from member names
[root@oldboyedu59 ~]# date +%F
2019-04-28
[root@oldboyedu59 ~]# tar zcf /tmp/etc-$(date +%F).tar.gz  /etc/ 
tar: Removing leading `/' from member names
[root@oldboyedu59 ~]# tar xf  /tmp/etc-2019-04-28.tar.gz -C  /opt/

14.5.2#第2个里程碑-书写脚本并测试脚本

###书写脚本
[root@oldboyedu59 ~]# mkdir -p /server/scripts 
[root@oldboyedu59 ~]# cat  /server/scripts/bak-etc.sh 
#!/bin/bash
tar zcf /tmp/etc-$(date +%F).tar.gz  /etc/

###测试脚本
[root@oldboyedu59 ~]# sh  /server/scripts/bak-etc.sh
tar: Removing leading `/' from member names
[root@oldboyedu59 ~]# ll /tmp/etc-2019-04-28.tar.gz 
-rw-r--r-- 1 root root 10212309 Apr 28 09:52 /tmp/etc-2019-04-28.tar.gz

14.5.3#第3里程碑-写入定时任务 每分钟执行 检查

root@oldboyedu59 ~]# crontab -l
#backup /etc/ to /tmp by liyy  at 20190101
* * * * *  sh  /server/scripts/bak-etc.sh  

  #检查  
##1.看日志 
tail -f /var/log/cron
##2.看结果
ll /bak-etc.sh 

14.5.4#第4个程碑-写入定时任务 根据要求修改时间

root@oldboyedu59 ~]# crontab -l
#show time by liyy  at 20190101
#*/2 * * * * date >>/tmp/time.log

14.5. 每天晚上12点打包备份/etv/目录到/tmp下

21:00到23:00小时 00:00点
#
#00  21-23,00 * * * date >>/tmp/time.log

#backup /etc/ to /tmp by liyy  at 20190101
00 00 * * *  sh  /server/scripts/bak-etc.sh  
#写法
[root@oldboyedu59 ~]# crontab -e
#show time by liyy  at 20190101
显示整列时间
每隔两分钟把时间重定向到/tmp/time.log  错误和对的信息都输入进文件
#*/2 * * * * date                              >>/tmp/time.log     2>&1
#* * * * * date +\%F_\%w                       >>/tmp/time.log     2>&1
#
#00  21-23,00 * * * date                       >>/tmp/time.log     2>&1 

#backup /etc/ to /tmp by liyy  at 20190101
00 00 * * *  sh  /server/scripts/bak-etc.sh     >/dev/null         2>&1 

14.6.1一定要加上一个注释
14.6.2书写定时任务的时候 尽量使用脚本
14.6.3脚本运行使用sh
14.6.4定时任务 %有特殊含义
14.6.5在定时任务中命令和脚本 使用绝对路径

which 命令
(1)用户的定时任务
用户家目录

(2)系统的定时任务
根下
14.6.6在定时任务里面 每个命令或脚本 走向到空 或追加带文件
预备姿势
/dev/null 黑洞

写法
00 00 * * * sh /server/scripts/bak-etc.sh >/dev/null 2>&1

原因

故障案例

14.6.7定时任务运行脚本环境变量问题

(1)定时任务运行脚本的时候PATH只识别/usr/bin和/bin下面的命令
PATH查找命令所运行的命令解释器
(2)解决
使用命令绝对路径
脚本开始 重新设置 PATH
定时任务遇到的坑
. /etc/profile

source /erc/profile

原因

如果不定向到空或追加到文件

定时任务会以邮件的形式把 输出到屏幕的内容 发给你

企业故障案例:定时任务没有定向到空或追加到文件的故障

1.系统邮件服务开启
你就会不断收到邮件
You hava new mail in /var/spool/mail/root

2.系统邮件服务关闭(大部分情况)
把没有发送出去的邮件 临时放起来
/var/spool/postfix/maildrop (这个目录下面会有大量的小文件)
inode满了

【故障演示】:You hava new mail in /var/spool/mail/root

邮件服务开启的时候

crontab -l 
#print xxxx
* * * * * echo {1..100}

邮箱内容

Received: by oldboyedu59.localdomain (Postfix, from userid 0)
        id 58C33405A0A6; Sun, 28 Apr 2019 11:28:01 +0800 (CST)
From: "(Cron Daemon)" <root@oldboyedu59.localdomain>
To: root@oldboyedu59.localdomain
Subject: Cron <root@oldboyedu59> echo {1..100} 
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env: <XDG_SESSION_ID=79>
X-Cron-Env: <XDG_RUNTIME_DIR=/run/user/0>
X-Cron-Env: <LANG=en_US.utf8>
X-Cron-Env: <SHELL=/bin/sh>
X-Cron-Env: <HOME=/root>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=root>
X-Cron-Env: <USER=root>
Message-Id: <20190428032801.58C33405A0A6@oldboyedu59.localdomain>
Date: Sun, 28 Apr 2019 11:28:01 +0800 (CST)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84  85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100

【故障演示】系统邮件服务关闭(大部分情况) 把没有发送出去的邮件 临时放起来

定时任务内容:

此时定时任务 没有定向到空或追加到文件

crontab -l 
#show cron errors by liyy  at 20190101 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 
* * * * * dae 

查看日志

[root@oldboyedu59 ~]# tail /var/log/cron 
Apr 28 11:48:34 oldboyedu59 CROND[32067]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32068]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32069]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32070]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32071]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32072]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32066]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32063]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32064]: (root) CMD (dae )
Apr 28 11:48:34 oldboyedu59 CROND[32065]: (root) CMD (dae )

查看临时目录

可以发现 邮件临时目录有大量小文件
日积月累会导致占用系统大量inode

[root@oldboyedu59 ~]# ll /var/spool/postfix/maildrop/|head -20
total 7208
-rwxr--r-- 1 root postdrop 447 Apr 28 11:48 003888026AC0
-rwxr--r-- 1 root postdrop 525 Apr 28 11:48 004DA8024270
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0054D801F68B
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 005728025B34
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0071F80268C6
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0083C801F4DE
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0084C8024D3B
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 00BDD8024F7E
-rwxr--r-- 1 root postdrop 526 Apr 28 11:48 00CB9802640D
-rwxr--r-- 1 root postdrop 525 Apr 28 11:48 00D0D8024006
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 00D1280253E9
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 00F4E80258F3
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 0164480253EA
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 018518026AC1
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 018BA802662F
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 019B08024F7F
-rwxr--r-- 1 root postdrop 448 Apr 28 11:48 01A45801F4DF
-rwxr--r-- 1 root postdrop 526 Apr 28 11:48 01B0B8025FAB
-rwxr--r-- 1 root postdrop 526 Apr 28 11:48 01BE680261D3

解决方案:定向到空或追加到文件

每分钟 显示当前系统的时间和ip地址 追加到 /tmp/ip.log中

date 
ip a s eth0
[root@oldboy59 scripts]# cat /tmp/ip.log
time:Sun Apr 28 12:02:01 CST 2019
ip: 10.0.0.200


[root@oldboy59 scripts]# cat ip.sh 
echo time:`date`  
echo  ip: `/usr/sbin/ip a s eth0|awk -F"[ /]+"  'NR==3{print $3}'`  



[root@oldboy59 scripts]# crontab -l |tail -1 
* * *  * * sh /server/scripts/ip.sh >>/tmp/ip.log   2>&1

[root@oldboy59 scripts]# cat /tmp/ip.log
time:Sun Apr 28 12:02:01 CST 2019
ip: 10.0.0.200
[root@oldboy59 scripts]# 
执行: ls 
1.系统会在PATH里面进行查找  

[root@oldboyedu59 ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
2. 这里面的路径中有  :命令解释器bash 执行 

3. 这里 没有         :command not found

基础:
每天晚上12点打包备份/etc/目录到/tmp下面
每天晚上12点打包备份/etc/目录到/backup 删除7天之前的备份
【面试题】定时任务
https://www.jianshu.com/p/d902ef6d3cf5

挑战:
1.每天晚上12点打包备份/etc/目录到/backup 删除7天之前的备份 但是要保留每周1的备份

终极挑战:
1.每天晚上12点打包备份/etc/目录到/backup/ip地址命名目录 删除7天之前的备份 但是要保留每周1的备份
/backup/10.0.0.200

下次磁盘管理:

磁盘分区 mbr
命令

今日提示集合:

 "/etc/sudoers.tmp" 125L, 4588C written
>>> /etc/sudoers: syntax error near line 105 <<<
                  语法错误 在105行
                  
[sudo] password for oldboy: 
Sorry, user oldboy may not run sudo on oldboyedu59. 
    
    
1.
[root@oldboyedu59 ~]# crontab -l
no crontab for root
root用户没有定时任务 
 
2.no crontab for root - using an empty one
root用户没有定时任务  创建1个空的文件 


3.crontab: installing new crontab
           更新定时任务规则 

4.
#mei liangfenzhong xianshi xitong shijian zhuijiadao /tmp/oldboy.txt
* /1 * * * date  >>/tmp/oldboy.txt

"/tmp/crontab.5UZIdI" 3L, 115C written
crontab: installing new crontab
"/tmp/crontab.5UZIdI":3: bad hour
errors in crontab file, can't install.
Do you want to retry the same edit?
要重试相同的编辑吗?


*/1 * * * * date  >>/tmp/oldboy.txt

5.
You have new mail in /var/spool/mail/root
你有1个新邮件 在/var/spool/mail/root 

相关文章

  • 2019-04-28定时任务(下)

    每天晚上12点 打包备份/etc/目录到/tmp下面 14.5.1#第一个里程碑-命令行测试{测试命令是否ok} ...

  • Python定时任务(下)

    上篇文章,我们了解到有三种办法能实现定时任务,但是都无法做到循环执行定时任务。因此,需要一个能够担当此重任的库。它...

  • 2019-07-31定时任务

    定时任务 定时任务实现方法 系统默认定时任务 用户自定义设置定时任务 定时任务配置文件 定时任务启动 定时任务样例...

  • 180803-Spring定时任务高级使用篇

    Spring定时任务高级使用篇 前面一篇博文 《Spring之定时任务基本使用篇》 介绍了Spring环境下,定时...

  • SpringBoot定时任务

    项目中很多时候会使用到定时任务,这篇文章介绍一下springboot整合定时任务。 springboot整合定时任...

  • SpringBoot定时任务

    项目中很多时候会使用到定时任务,这篇文章介绍一下springboot整合定时任务。 springboot整合定时任...

  • Linux定时任务Crontab

    一、定时任务 1、在讲什么是Linux当中的定时任务,我们先说一下什么是定时任务? 在平时生活中,大家都会遇到一些...

  • laravel 设置定时任务(任务调度)

    创建定时任务 查看定时任务 定义调度 在App\Console\Commands下创建Test.php 编辑 ap...

  • linux下的定时任务-crontab

    在linux下,有时我们有一些定时任务需要执行,这时我们使用crontab命令来配置定时任务。在linux下用来周...

  • 分布式定时调度-xxl-job

    一、定时任务概述 1.1 定时任务认识 1.1.1 什么是定时任务 定时任务是按照指定时间周期运行任务。使用场景为...

网友评论

      本文标题:2019-04-28定时任务(下)

      本文链接:https://www.haomeiwen.com/subject/aehjnqtx.html