Linux云计算学习笔记day24

Stella981
• 阅读 627

每天晚上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天之前的备份
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
美凌格栋栋酱 美凌格栋栋酱
9小时前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(