计划任务

作业管理:

Linux的作业控制(job )
    前台作业:通过终端启动,且启动后一直占据终端;
    后台作业:可通过终端启动,但启动后即转入后台运行(释放终端)
如何让作业运行于后台?
    (1) 运行中的作业: Ctrl+z 注意:运送到后台,作业会成休眠状态 
    (2) 尚未启动的作业: # COMMAND &
后台作业虽然被送往后台运行,但其依然与终端相关;退出终端,将关闭后台作业。如果希望送往后台后,剥离与终端的关系
    # nohup COMMAND & 或    screen;COMMAND
查看所有作业:
    # jobs
作业控制:
    # fg [[%]JOB_NUM]:把指定的后台作业调回前台;(front ground)
    # bg [[%]JOB_NUM]:让送往后台的作业在后台继续运行;()
    #kill -18  [% JOB_NUM]  继续执行某命令
    #kill -19  [% JOB_NUM]  把某命令放到后台休眠  
        注意:使用kill命令删除作业,作业号前必须加%号

计划任务

并行运行: 同时运行多个进程,提高效率
 (1) 写脚本.调写其他我那文件名实时
 (2)    (f1.sh&);(f2.sh&);(f3.sh&)
 (3)   { f1.sh& f2.sh& f3.sh& }

邮件:

本地的邮件服务,支持不同本地主机用户传递信息工具

用户邮件保存位置:/var/spool/mail/usernema

dsfdds
  (1)查看(邮件服务自动开启)
      #netstat -tnlp 查看邮件的服务地址和端口   127.0.0.1:25
      #ss -tnl
  (2)协议:
      smtp:slmple mail transmlssion protocol
      pop3:Post Office Procotol
      lmap4:Internet Mail Access Procotol
  (3)命令管理
      mail命令:(MUV:Mail User Agent 用户收发邮件的工具程序)
          mailx -send and receive Internet mail
        使用方式:
          发邮件:
            (1)交互式输入:
                mailx [options] "主题" 用户名  邮件正文   点号单独一行结束
                [root@wen-7 ~]# mailx -s "help" wen
                sdfjdf
                dfdasadsfdsa
                .
                EOT
            (2)重定向正文
                mailx -s "help" wen << "dkljfkldasfjkldkfljd"
            (3)通过管道;命令的执行结果
                [root@wen-7 ~]# cat /etc/fstab | mail -s "fdsf" wen

          收邮件:
              mailx 命令   输入邮件编号
              按q退出

         邮件重定向:
              mail

Linux计划任务

企业最重要的是数据,要求运维人员定期备份数据,大量的备份工具不可能手工完成,只能借助周期计划任务工具.
未来的某时间点执行一次任务:at batch
周期性运行某任务 :crontab

执行结果:会通过邮件发送给用户

at命令:

语法:
  at [Options] ...TIME   (自动回车,输入执行命令;Ctrl+d结束输出,完成任务)

选项:options
    -M:执行任务后,主动发邮件,即使没有标准输出tions: (at的作业有队列,用单个字母表示,默认为a)
    -v:显示at的版本号
    -l:查看当前任务列表 (等待执行的作业)
    -f /PATH/FROM/SOMEFILE:从指定文件中服务作业任务,不用在交互确认
    -d #:删除执行编号的作业
    -c:查看指定组而已的具体内容
    -q QUEUE:指明队列
    注意: 计划任务中的标准输出,会给用户发邮件.大量的垃圾邮件会占用磁盘空间.作业执行结果是有邮件发送给提交作业的用户
时间格式: Time:
    HH:MM[YYYY-mm-dd]  规定在某年某月的某一天的特殊时刻进行该项任务
    none,mignight,teatime,tomorrow
    now+#{ minutes,hours,days,OR weeks}  在某个时间点再加几个时间后才进行该项任务

    [root@Wencx ~]# at -V
    at version 3.1.10
    [root@Wencx ~]# at  9:08
    at> bash z.sh           
    at> <EOT>
    job 2 at 2016-09-09 09:08
    [root@Wencx ~]# at -l
    2    2016-09-09 09:08 a root
    [root@Wencx ~]# at -c 2
    #!/bin/sh
    # atrun uid=0 gid=0
    # mail root 0
    ${SHELL:-/bin/sh} << 'marcinDELIMITER035951f0'
    bash z.sh
    [root@Wencx ~]# at -l
    2    2016-09-09 09:08 a root
    [root@Wencx ~]# at -d 2
    [root@Wencx ~]# at -l


    [root@Wencx ~]# at -m 20:35
    at> ls /etc
    at> <EOT>
    job 4 at 2016-09-08 20:35
    [root@Wencx ~]# mail
    Heirloom Mail version 12.4 7/29/08.  Type ? for help.
    "/var/spool/mail/root": 1 message 1 new
    >N  1 root                  Thu Sep  8 20:35 208/2258  "Output from your job        4"
    & 1
    Date: Thu,  8 Sep 2016 20:35:01 +0800 (CST)
    From: root@Wencx.localdomain (root)
    Status: R

    DIR_COLORS
    DIR_COLORS.256color

执行方式:
    1)交互式 2)输入重定向 3) at –f 文件

at服务:    
     依赖与atd服务,需要启动才能实现at任务
     管理服务脚本:
        6./etc/rc.d/init.d/atd
        7./usr/lib/systemd/system/atd.service
     使用此命令,要开启atd服务
        命令:service atd start
        桌面:setup,ntsysv

计划任务
计划任务

     开机自启动:
        chkconfig --level atd on 
at队列:
     at队列存放在/var/spool/at目录中,每个文件名都对应队列任务的序号

计划任务

at配置文件

    通过/etc/at.{allow,deny}控制用户是否能执行at任务,寻找/etc/at.allow文件,文件中的使用者才能使用at,没有在这个文件中的使用者则不能使用 at (即使没有写在at.deny 当中)
    如果/etc/at.allow 不存在,就寻找 /etc/at.deny 这个文件,若写在这个 at.deny 的使用者则不能使用 at,而没有在这个 at.deny 文件中的使用者则可使用 at 命令。
    如果两个文件都不存在,只有 root 可以使用 at 这个命令。

batch命令:

   batch会让系统自行选择在空闲时间去执行指定的任务;
   指明任务的细节与at一样

run-parts命令:执行一个目录下的所有脚本
crontab:周期性任务计划

   机制:cron
   服务程序:
      cronie:主程序包,提供了crond守护进程和相关辅助工具
          确保crond守护进程处于正常运行状态:
              centos6: /etc/rc.d/init.d/crond 服务脚本
                    service crond status
              centso7: /usr/lib/systemd/system/crond.service服务脚本
                    systemctl status crond.service
      cronie-anacron: cronie的补充程序;用于监控cronie任务执行状况;如cronie中的任务在过去该运行的时间点未能正常运行,则anacron会随后启动一次此任务
      crontabs:包含CentOS提供系统维护任务    
   cron文件:
        日志文件:/var/log/cron
        管理员配置文件:/etc/crontab
        用户配置文件:/etc/cron.d/ 
        小时脚本目录:    /etc/cron.hourly/  
        每天脚本目录:    /etc/cron.daily/   
        每周脚本目录:    /etc/cron.weekly/  
        每月脚本目录:    /etc/cron.monthly/ 
        (用户可把要执行的任务写入文件中,放入对应的目录中,完成执行周期)

   向crond提交作业的方式不同于at,他需要使用专门的配置文件,此文件有固定格式,不建议使用文本编辑器直接编辑此文件 ,要使用crontab命令
   cron任务分为两类:
      系统cron任务:主要用于实现系统自身的维护;
          手动编辑:/etc/crontab文件
      用户cron任务: 用户自己的周期任务
          使用命令:crontab

      系统cron的配置方式:
         系统cron任务:/etc/crontab
         注释行以 # 开头
         详情参见 man 5 crontab

             SHELL=/bin/bash
             PATH=/sbin:/bin:/usr/sbin:/usr/bin
             MAILTO=root
             # For details see man 4 crontabs
             # Example of job definition:
             # .---------------- minute (0 - 59)
             # |  .------------- hour (0 - 23)
             # |  |  .---------- day of month (1 - 31)
             # |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
             # |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) ORsun,mon,tue,wed,thu,fri,sat
             # |  |  |  |  |
             # *  *  *  *  * user-name  command to be executed
             注意:
                (1)每一行定义一个周期性任务; 共7个字段
                      *  *  *  *  * : 定义周期性时间
                       user-name  :运行任务的用户身份
                       command to be executed: 任务(执行命令一定要加绝对路径)
                (2)此处的环境变量不同于用户登录后获得的环境,因此,建议命令使用绝对路径,或自定义PATH环境变量
                (3)执行结果邮件发送给MAILTO指定的用户

      用户cron的配置方式:
         文件存放于/var/spool/cron/USERNAME

              *  *  *  *  *  command to be executed
           注意:
            (1)每一行定义一个周期性任务; 共6个字段
                 *  *  *  *  * : 定义周期性时
                 command to be executed: 任务
            (2)此处的环境变量不同于用户登录后获得的环境,因此,建议命令使用绝对路径
            (3)执行结果邮件发送给的当前用户

    时间表示法:
        (1)特定值:
             给定时间点有效取值范围内的值(日期范围)
               注意:days of week和day of month一般不同时使用;
        (2)*
             给定时间点上有效取值范围内的所有值;表示"每" 之意
                 例:* * * * *:表示每分钟执行
                    * 1 * * *:表示每小时执行 
        (3)离散取值:,
             在时间点上使用逗号分隔的多个值;
                #,#,#   1,2,3
                 例: 2,5,8月执行
                    0 * * 2,5,8 * centos /bin/echo "howdy!"
        (4)连续值:
                #-#     1-3
                 例:每月前3周
                    0 * * * 1-3 centos /bin/echo "howdy!"
        (5)在指定范围内,指定范围
                #/M    
                例:每3小时echo命令;
                    0 */3 * * * centos /bin/echo "howdy!"
        (6)范围值
                @reboot Run once after reboot.   每次重启时执行定时任务
                @yearly      0 0 1 1 *             每一年的第一分钟执行定时任务
                @annually    0 0 1 1 *             每月每天
                @monthly     0 0 1 * *             每月执行定时任务
                @weekly      0 0 * * 0             每周每天    
                @daily       0 0 * * *             每天执行定时任务
                @hourly      0 * * * *           每分钟

            注意:在有日期的情况下,还加上星期范围,这两种时间将是或的执行关系
         实例:

            (1)3 * ***: 每小时执行一次:每小时的第3分钟执行一次
            (2)3 4 * * 5:每周执行一次.每周5的四点三分
            (3)5 6 7 **:每月执行一次.每月的7号的6点5分
            (4)7 8 9 10 *:每年执行一次,每年的10月9号8点7分
            (5)8 8 * * 3,7:,每周三和周日的8点9分
            (6)0 8,20 * * 3,7:   每周三周日的20点和8点
            (7)0 9-18  * * 1-5; 每周一到周五的9-18点
            (8)*/5 * * * * * 每5分钟执行一次
            (9)*/7            每7分钟执行一次

   crontab命令:
      crontab [-u user] [-l][-r][-e][-s]
      选项:
         -e:打开文件,编写计划
         -l:查看任务列表
         -r:移除所有任务,即删除/var/spool/cron/USERNAME文件;
         -i:与-r配合使用,交互式删除计划任务
         -u user:root用户可为指定用户管理cron任务

        查看当前用户定时任务
            ramesh@dev-db$ crontab -l
        查看 ROOT 用户定时任务,用 root 登入 su-root,再执行 crontab -l
            root@dev-db# crontab -l
                no crontab for root
        查看其它用户定时任务
            root@dev-db# crontab -u sathiya -l
            @monthly /home/sathiya/monthly-backup
            00 09-18 * * * /home/sathiya/check-db-status

       注意:运行结果以邮件方式通知给当前用户,如果拒绝接受邮件;
         (1) COMMAND > /dev/null
         (2)COMMAND &> /dev/null (有风险)
      注意:定义COMMAND时,如果命令中需要用到%号 ,需要对其转义;但放置于单引号中的%号不用转义
      思考:某任务在指定时间因关机未能执行,下次开机会不会自动执行?
             不会!
      课外作业:anacron及其应用


  练习:
    1.每12小时备份一次/etc/目录至/backups目录中,保存文件 名称格式为"etc-yyyy-mm-dd-hh.tar.xz"
    2.每周2,4,7备份/var/log/secure文件至/logs目录中,文件格式为:"secure-yyyymmdd"
    3.每两小时取出当前系统/proc/meminfo文件中以s或m开头的行信息追加至/tmp/meminfo.txt文件中
    4.每天4点打包/etc/目录
    * 4 * * *  /bin/tar Jvf  /backup/etc-`date +%F-%H-%M`.tar.xz /etc 

            1、每天6:00执行

            0 6 * * * root /home/www.osyunwei.com/osyunwei.sh

            2、每周六凌晨4:00执行

            0 4 * * 6 root /home/www.osyunwei.com/osyunwei.sh

            3、每周六凌晨4:05执行

            5 4 * * 6 root /home/www.osyunwei.com/osyunwei.sh 

            4、每周六凌晨4:15执行

            15 4 * * 6 root /home/www.osyunwei.com/osyunwei.sh

            5、每周六凌晨4:25执行

            25 4 * * 6 root /home/www.osyunwei.com/osyunwei.sh

            6、每周六凌晨4:35执行

            35 4 * * 6 root /home/www.osyunwei.com/osyunwei.sh

            7、每周六凌晨5:00执行

            5 * * 6 root /home/www.osyunwei.com/osyunwei.sh

            8、每天8:40执行

            40 8 * * * root /home/www.osyunwei.com/osyunwei.sh

            9、每天8:30执行

            30 8 * * * root /home/www.osyunwei.com/osyunwei.sh

            10、每周一到周五的11:41开始,每隔10分钟执行一次

            41,51 11 * * 1-5   root /home/www.osyunwei.com/osyunwei.sh

            1-59/10 12-23 * * 1-5   root /home/www.osyunwei.com/osyunwei.sh

            11、在每天的10:31开始,每隔2小时重复一次

            31 10-23/2 * * * root   /home/www.osyunwei.com/osyunwei.sh

            12、每天15:00执行

            0 15 * * *  root /home/www.osyunwei.com/osyunwei.sh

            13、每天的10:30开始,每隔2小时重复一次

            30 10-23/2 * * * root  /home/www.osyunwei.com/osyunwei.sh

            14、每天15:30执行

            30 15 * * *  root /home/www.osyunwei.com/osyunwei.sh

            15、每天17:50执行

            50 17 * * *  root /home/www.osyunwei.com/osyunwei.sh

            16、每天8:00执行

            0 8 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            17、每天18:00执行

            0 18 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            18、每天8:30执行

            系统运维 www.osyunwei.com 温馨提醒:qihang01原创内容版权所有,转载请注明出处及原文链接

            30 8 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            19、每天20:30

            30 20 * * *  root /home/www.osyunwei.com/osyunwei.sh

            20、每周一到周五2:00

            0 2 * * 1-5 root /home/www.osyunwei.com/osyunwei.sh

            21、每周一到周五9:30

            30 9 * * 1-5 root /home/www.osyunwei.com/osyunwei.sh

            22、每周一到周五8:00,每周一到周五9:00

            0 8,9 * * 1-5  root /home/www.osyunwei.com/osyunwei.sh

            23、每天23:59

            59 23 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            24、每周六23:59

            59 23 * * 6  root    /home/www.osyunwei.com/osyunwei.sh

            25、每天0:30

            30 0 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            26、每周一到周五9:25到11:35之间、13:00到15:00之间,每隔10分钟运行一次

            25,35,45,55  9 * * 1-5  root   /home/www.osyunwei.com/osyunwei.sh

            5-59/10  10 * * 1-5  root   /home/www.osyunwei.com/osyunwei.sh

            5,15,25,35  11 * * 1-5  root   /home/www.osyunwei.com/osyunwei.sh

            */10  13-15 * * 1-5  root   /home/www.osyunwei.com/osyunwei.sh

            27、每周一到周五8:30、8:50、9:30、10:00、10:30、11:00、11:30、13:30、14:00、14:30、5:00分别执行一次

            30,50 8 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            30 9 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            */30 10-11 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            30 13 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            0,30 14-15 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            28、每天23:50执行

            50 23 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            29、每天10:00、16:00执行

            0 10,16 * * *  root /home/www.osyunwei.com/osyunwei.sh

            30、每天5:30执行

            30 5 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            31、每周一到周五9:30执行

            30 9 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            32、每周一到周五13:00执行

            0 13 * * 1-5  root  /home/www.osyunwei.com/osyunwei.sh

            33、每天7:51执行

            51 7 * * *  root /home/www.osyunwei.com/osyunwei.sh

            34、每天7:53、12:40分别执行一次

            53 7 * * *  root /home/www.osyunwei.com/osyunwei.sh

            40 12 * * *  root /home/www.osyunwei.com/osyunwei.sh

            35、每天7:55执行

            55 7 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            36、每天8:10、16:00、20:00分别执行一次

            10 8 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            0 16 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            0 20 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            37、每天7:57、8:00分别执行一次

            57 7 * * *  root  /home/www.osyunwei.com/osyunwei.sh

            0 8 * * *  root  /home/www.osyunwei.com/osyunwei.sh

原创文章,作者:wencx,如若转载,请注明出处:http://www.178linux.com/44666

(0)
wencxwencx
上一篇 2016-09-08
下一篇 2016-09-09

相关推荐

  • Apache、nginx 、lighttpd性能比较

    1. web服务器简介 1. lighttpd      Lighttpd是一个德国人领导的开源软件,其根本的目的是提供一个专门针对高性能网站,安全、快速、兼容性好并且灵活的Web server环境         Lighttpd是一个具有非常低的…

    Linux干货 2015-04-10
  • 8.5文本处理工具及正则表达式

    一、各种文本工具     文件查看     命令:cat,tac,rev         cat optiong file       &n…

    Linux干货 2016-08-10
  • shell脚本编程之变量

    一、创建shell脚本文件   创建shell脚本时,必须在第一行指定要使用的shell。格式为:   #!/bin/bash   通常在shell脚本中,#代表注释行,即不被执行的行,而第一行“#!”则是表示用哪个shell来执行脚本。   实例:   让我们来执行一下这个脚本:   上面的结果显…

    Linux干货 2016-02-14
  • Raid的工作原理

    1,什么是Raid Raid的基本原理就是把多个磁盘组合到一起,组成一个磁盘组,使性能达到或超过一个容量巨大价格昂工艺的磁盘,当然基于硬件的RAID解决方案比基于软件RAID技术在使用性能和服务性能上稍胜一筹,具体表现在检测和修复多位错误的能力、错误磁盘自动检测和阵列重建等方面。 2.RAID级别介绍;一般常用的RAID阶层,分别是RAID 0、RAID1、…

    Linux干货 2017-06-19
  • 马哥教育网络班21期+第四周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 ~]# cp -r /etc/skel /home/tuser1; chmod -R gx=— /home/tuser1 [root@mag…

    Linux干货 2016-08-02
  • N25_第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@aio ~]# who|cut -d" " -f1|uniq root 2、取出最后登录到当前系统的用户的相关信息。 [root@aio ~]# who| …

    Linux干货 2016-12-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-10 11:26

    写的很详细,尤其是对时间上的论述部分,赞一个,继续加油!!!