美文网首页
Linux云计算学习笔记day24

Linux云计算学习笔记day24

作者: 我要笑 | 来源:发表于2019-04-28 20:47 被阅读0次

    每天晚上09点到12点运行 systemctl restart network 命令
    每天上午7点到12点每2个小时和晚上22点运行 systemctl restart network 命令

    每天晚上09点到12点运行 systemctl restart network 命令
    00 21-00 * * * systemctl restart network ×

    • 21-00 * * * systemctl restart network ×
      00 21-23,00 * * * date >>/tmp/time.log √√√√√

    每天上午7点到12点每2个小时和晚上22点运行 systemctl restart network 命令
    00 7-12/2,22 * * * systemctl restart network

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

    第1个里程碑-命令行测试 (测试命令是否ok)

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

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

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

    第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/
    

    第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
    

    第3个里程碑-写入定时任务 每分钟 检查

    [root@oldboyedu59 ~]# crontab -l

    backup /etc/ to /tmp by liyy at 20190101

            • sh /server/scripts/bak-etc.sh

    检查

    1.看日志

    2.看结果

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

    [root@oldboyedu59 ~]# crontab -l

    show time by liyy at 20190101

    */2 * * * * date >>/tmp/time.log

    00 21-23,00 * * * date >>/tmp/time.log

    backup /etc/ to /tmp by liyy at 20190101

    00 00 * * * sh /server/scripts/bak-etc.sh

    在定时任务里面 每个命令或脚本 定向到空 或追加到文件
    定时任务中 命令或脚本 输出信息

    预备姿势

        /dev/null 定向到黑洞 
        >/dev/null  2>/dev/null 正确的信息 错误信息 定向到黑洞中 
        >/dev/null  2>&1        正确的信息 错误信息 定向到黑洞中 
        &>/dev/null             正确的信息 错误信息 定向到黑洞中 
    
        追加到文件 
        >>/tmp/cron.log   2>&1        正确的信息 错误信息 定向到黑洞中 
    

    写法

    [root@oldboyedu59 ~]# crontab -e
    #show time by liyy  at 20190101
    #*/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 
        
        
    #原因
    如果不定向到空或追加到文件 
    定时任务会以邮件的形式把 输出到屏幕的内容 发给你 
        
        企业故障案例:定时任务没有定向到空或追加到文件的故障
    
    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天之前的备份

    相关文章

      网友评论

          本文标题:Linux云计算学习笔记day24

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