系统管理之作业管理与计划任务

作业管理:

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命令:执行一个目录下的所有脚本
readlink 命令 查看文件软连接的文件名
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/46003

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

相关推荐

  • linux 文本处理工具 grep cut sort等

    linux day 7 间歇性回忆 自动属于这个组 是  SGID 的功能 chmod g+s /data/testdir setfacl —m g:g2:rwx /data/testdir setfacl -m b:g:g2:rwx /data/testdir setfacl -m d:g:g3:r testdir chmod o= testdi…

    Linux干货 2016-08-08
  • 20160803作业-用户组和权限管理

    http://note.youdao.com/yws/public/redirect/share?id=46f06331b737c6d08a0e8c9c3d49ac9e&type=false

    Linux干货 2016-08-08
  • iptables 初识

    iptables 包过滤性防火墙     iptables是位于用户空间,是防火墙管理配置规则的工具。     iptables的作用:用来添加,删除,管理netfilter规则。     Netfilter是位于内核中真正的防火墙,由5个钩子组成,…

    Linux干货 2016-06-01
  • 简述一些基础指令

    tree命令 tree -L 1 -d /用来查看目录结构 -L 指定层数 -d 只查看目录 /boot 跟内核有关的文件 grub 内核和BootLoader ├── bin 存放用户使用的基本命令(可执行程序,二进制文件) 不能单独分区的 ├── boot 跟内核有关的文件 grub 内核和BootLoader&n…

    Linux干货 2017-04-03
  • RAID磁盘阵列

    什么是RAID?    RIAD(Redundant Array of Independent Disk,独立冗余磁盘阵列)技术是加州大学伯克利分校1987年提出,最初是为了组合小的廉价磁盘来代替大的昂贵磁盘,同时希望磁盘失效时不会使对数据的访问受损失而开发出一定水平的数据保护技术。RAID就是一种由多块廉价磁盘构成的冗余阵列,在操作系统下是作为一个独立的大…

    Linux干货 2016-12-13
  • Linux的终端类型

    Linux的终端类型 Linux的终端类型: TTY(虚拟终端,图形终端) 早期的电子计算机的输入设备是穿孔卡片【又称霍列瑞斯式卡(Herman Hollerith)或IBM卡】,用有洞和无洞表示计算机二进制里面的0和1,以此来记录相关信息,但是这种方式很慢。 1986年股票代码被发明,人们通过电报和电传打印机发送实时股票价格,此时teletypewrite…

    Linux干货 2016-10-14