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

作业管理:

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

相关推荐

  • N25_第一周博客作业

    一、计算机组成及其功能      1、CPU:          运算器:计算功能,对数据进行加工处理的部件。          控制器:负责从存储器读取指令,控制计算器之间的运行状态和结果;     &nbs…

    Linux干货 2016-12-04
  • 学习积累01#计算机组成#Linux版本#基本命令

    第一周的积累 问题1:描述计算机的组成及其功能 CPU:中央处理器,主要功能是进行运算和逻辑运算,内部大致可分为控制单元、逻辑算术单元、存储单元; 主板:核心部件,是电脑的“脉络”,CPU\内存\控制核心电路均安装在主板上,各种外部设备也通过主板上的插槽相互连接; 硬盘:常见的外存储器,容量大,保存时间长、安全性高。接口主要分为IDE、SATA、SCSI。 …

    Linux干货 2016-10-25
  • N28-第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。
    2、取出最后登录到当前系统的用户的相关信息。
    3、取出当前系统上被用户当作其默认shell的最多的那个shell。
    4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。
    5、取出当前主机的IP地址,提示:对ifconfig命令的结果进行切分。
    6、列出/etc目录下所有以.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中。
    7、显示/var目录下一级子目录或文件的总个数。
    8、取出/etc/group文件中第三个字段数值最小的10个组的名字。
    9、将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中。
    10、请总结描述用户和组管理类命令的使用方法并完成以下练习:
    (1)、创建组distro,其GID为2016;
    (2)、创建用户mandriva, 其ID号为1005;基本组为distro;
    (3)、创建用户mageia,其ID号为1100,家目录为/home/linux;
    (4)、给用户mageia添加密码,密码为mageedu;
    (5)、删除mandriva,但保留其家目录;
    (6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;
    (7)、修改slackware的默认shell为/bin/tcsh;
    (8)、为用户slackware新增附加组admins;

    2017-12-17
  • httpd协议配置进阶

    目录 虚拟主机配置 status状态页面 curl命令 mod_deflate模块 https配置 httpd自带应用程序 虚拟主机配置 有三种实现方案:    基于IP:        为每个虚拟主机准备至少一个IP地址    基于端口:     &nbsp…

    Linux干货 2016-10-31
  • 模拟centos6.8系统下initramfs文件和vmlinuz文件损坏恢复

    实验一:关于删除initramfs-2.6.32-642.el6.x86_64.img 文件恢复实验,实验环境centos6.8系统 1.安全起见,请先安排做快照及备份 把initramfs-2.6.32-642.el6.x86_64.img 文件复制一份/root目录下。 [root@centos6: boot]# cp -a initramfs-2.6.…

    2017-05-15
  • net25-第17周作业

    1、结合图形描述LVS的工作原理; lvs-nat模型,相当于多目标的dnat,通过将请求报文中的目标地址和目标端口修改为调度出的rs的rip和port来实现转发,整个请求如下: cip -> vip -> vs(nat转换) -> rip  请求 rip -> dip(默认网关) -> vs(nat转换) ->…

    Linux干货 2017-05-15