Linux下的定时任务 - Cron服务

最近搞咕自己的笔记系统,虽然现在是个人的使用,对于数据库的数据还是比较少,但是安全还是一个我必须注意的东西.

(特别是前段时间中了比特币的病毒之后,更是让我关注了我的主机的安全的问题.)

今天的随记是聊聊crontab服务时间linux环境下的定时任务.

 

首先,我们需要linux下的一个定时工具:crontab ,这款工具其实和java的Quartz任务调度是类似的。

首先没有安装的crontab的,需要安装:

yum install  crontab

然后使用命令:

crontab -e

【注:这条命令会打开类似vim编辑器,我们只需要用vim相同的操作,在里面写下任务的脚本即可!】

进入编辑界面,直接输入:

 */2 * * * * /bin/sh /home/jiaoben/XXX.sh

这样,我们的一个任务就OK了,正式生效了。

*/2 * * * * 通过这段字段可以设定什么时候执行脚本;

 /bin/sh /home/jiaoben/XXX.sh

这一字段可以设定你要执行的脚本,这里要注意一下/bin/sh 是"运行 脚本的命令", 后面一段时指脚本存放的路径.

通过上面的简单的一步就可以实现一个定时任务.

 

我们怎么知道是否启动成功呢?

>> 查看该用户下的crontab服务是否创建成功, 用 crontab  -l 命令 

 

 

下面来具体的关注一下crontab:

------------------------------------------------------------------------------

(1)启动crontab服务:

  一般启动服务用  /sbin/service crond start 若是根用户的cron服务可以用 sudo service crond start, 这里还是要注意  下 不同版本linux系统启动的服务的命令也不同 ,像我的虚拟机里只需用 sudo service cron restart 即可,若是在根用下直接键入service cron start就能启动服务

(2) 查看服务是否已经运行用

  ps -ax | grep cron

(3) crontab命令

      cron服务提供crontab命令来设定cron服务的,以下是这个命令的一些参数与说明:    
        crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数      
  crontab -l //列出某个用户cron服务的详细内容    
  crontab -r //删除没个用户的cron服务    
  crontab -e //编辑某个用户的cron服务    
  比如说root查看自己的cron设置:crontab -u root -l    
  再例如,root想删除fred的cron设置:crontab -u fred -r    
  在编辑cron服务时,编辑的内容有一些格式和约定,输入:crontab -u root -e    
  进入vi编辑模式,编辑的内容一定要符合下面的格式:*/1 * * * * ls >> /tmp/ls.txt    
        任务调度的crond常驻命令    
        crond 是linux用来定期执行程序的命令。当安装完成操作系统之后,默认便会启动此      
       任务调度命令。crond命令每分锺会定期检查是否有要执行的工作,如果有要执行的工    
       作便会自动执行该工作。   

(4) crontab命令选项:

     -u指定一个用户        
     -l列出某个用户的任务计划        
     -r删除某个用户的任务        
     -e编辑某个用户的任务        

(5) cron文件语法:

      分     小时    日       月       星期     命令        
      0-59   0-23   1-31   1-12     0-6     command     (取值范围,0表示周日一般一行对应一个任务)        
     记住几个特殊符号的含义:        
         “*”代表取值范围内的数字,        
         “/”代表”每”,        
         “-”代表从某个数字到某个数字,        
         “,”分开几个离散的数字   

(6) 任务调度设置文件的写法:

      可用crontab -e命令来编辑,编辑的是/var/spool/cron下对应用户的cron文件,也可以直接修改/etc/crontab文件    
     具体格式如下:    
      Minute Hour Day Month Dayofweek   command    
      分钟     小时   天     月       天每星期       命令    
     每个字段代表的含义如下:    
     Minute             每个小时的第几分钟执行该任务    
     Hour               每天的第几个小时执行该任务    
     Day                 每月的第几天执行该任务    
     Month             每年的第几个月执行该任务    
     DayOfWeek     每周的第几天执行该任务    
     Command       指定要执行的程序    
     在这些字段里,除了“Command”是每次都必须指定的字段以外,其它字段皆为可选    
    字段,可视需要决定。对于不指定的字段,要用“*”来填补其位置。    
    举例如下:    
    5       *       *           *     *     ls             指定每小时的第5分钟执行一次ls命令    
    30     5       *           *     *     ls             指定每天的 5:30 执行ls命令    
    30     7       8         *     *     ls             指定每月8号的7:30分执行ls命令    
    30     5       8         6     *     ls             指定每年的6月8日5:30执行ls命令    
    30     6       *           *     0     ls             指定每星期日的6:30执行ls命令[注:0表示星期天,1表示星期1,    
    以此类推,也可以用英文来表示,sun表示星期天,mon表示星期一等。]    
   30     3     10,20     *     *     ls     每月10号及20号的3:30执行ls命令[注:“,”用来连接多个不连续的时段]    
    25     8-11 *           *     *     ls       每天8-11点的第25分钟执行ls命令[注:“-”用来连接连续的时段]    
    */15   *       *           *     *     ls         每15分钟执行一次ls命令 [即每个小时的第0 15 30 45 60分钟执行ls命令 ]    
     30   6     */10         *     *     ls       每个月中,每隔10天6:30执行一次ls命令[即每月的1、11、21、31日是的6:30执行一次ls 命令。 ]    
     每天7:50以root 身份执行/etc/cron.daily目录中的所有可执行文件    
     50   7       *             *     *     root     run-parts     /etc/cron.daily   [ 注:run-parts参数表示,执行后面目录中的所有可执行文件。 ]    

(7) 新增调度任务 :
     新增调度任务可用两种方法:    
       1)、在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。    
        2)、直接编辑/etc/crontab 文件,即vi /etc/crontab,添加相应的任务。    
(8)  查看调度任务    
        crontab -l //列出当前的所有调度任务    
        crontab -l -u jp   //列出用户jp的所有调度任务    
(9)  删除任务调度工作    
         crontab -r   //删除所有任务调度工作    
(10) 任务调度执行结果的转向    
       例1:每天5:30执行ls命令,并把结果输出到/jp/test文件中    
            30 5 * * * ls >/jp/test 2>&1    
            注:2>&1 表示执行结果及错误信息。    
      编辑/etc/crontab 文件配置cron      
     cron服务每分钟不仅要读一次/var/spool/cron内的所有文件,还需要读一次 /etc/crontab,因此我们配置这个文件也能运用cron服务做一些事情。用crontab配置是针对某个用户的,而编辑/etc/crontab是针对系统的任务。此文件的文件格式是:      
  SHELL=/bin/bash      
  PATH=/sbin:/bin:/usr/sbin:/usr/bin     
  MAILTO=root //如果出现错误,或者有数据输出,数据作为邮件发给这个帐号      
  HOME=/ //使用者运行的路径,这里是根目录      
  # run-parts      
  01   *   *   *   *     root run-parts /etc/cron.hourly         //每小时执行    
        /etc/cron.hourly内的脚本      
     02   4   *   *   *     root run-parts /etc/cron.daily           //每天执行/etc/cron.daily内的脚本      
       22   4   *   *   0     root run-parts /etc/cron.weekly       //每星期执行 /etc/cron.weekly内的脚本      
      42   4   1   *   *     root run-parts /etc/cron.monthly     //每月去执行/etc/cron.monthly内的脚本      
  大家注意”run-parts”这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名了    
    例如:    
     1) 在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。    
      2)直接编辑/etc/crontab 文件,即vi /etc/crontab,添加相应的任务    
          11 2 21 10 * rm -rf /mnt/fb      
-------------------------------------------------------------------------------------------

上面的总结的东西来源于互联网资料,那么这里就谈谈我用它来干什么吧,而且我前面也提及到安全,这里也一并的说了:

1、crontab定时任务我研究他是为了实现mysql的定时的备份。crontab是linux工具,可以定时的执行shell脚本,也就是说能够执行我们自己编写的shell脚本,这样我们可以实现定时干点什么。。。。应该懂了能干什么了吧。

 

2、所提及的安全问题是这样的,因为上次比特币病毒将我的mysql数据里给破坏了,数据丢失了,所以我需要一个工具,实现mysql的定时备份。

 

其实在解决mysql的定时备份,主要是有三种,当然欢迎大家提供更所的方案,这里将其列举如下:

(1) 执行mysqldump命令备份。

(2)Windows下面可以用批处理

(3)定时任务,我用的就时linux环境下的crontab工具实现定时的备份。

 

-----------------------------这是我的备份的数据------------------每天的00点01分--------------------------------------

-rw-r--r-- 1 root root  6935 Sep  9 22:47 yun11_20170909_224755.sql.gz
-rw-r--r-- 1 root root  9452 Sep 10 00:01 yun11_20170910_000101.sql.gz
-rw-r--r-- 1 root root 17868 Sep 11 00:01 yun11_20170911_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 12 00:01 yun11_20170912_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 13 00:01 yun11_20170913_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 14 00:01 yun11_20170914_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 15 00:01 yun11_20170915_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 16 00:01 yun11_20170916_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 17 00:01 yun11_20170917_000101.sql.gz
-rw-r--r-- 1 root root   352 Sep 18 00:01 yun11_20170918_000101.sql.gz

--------------------------这是我的shell脚本----------------------------------------------------------------------------------

mysqldump -ucustom -prunmysql-q yuncode2 | gzip > /home/yun11_$(date +%Y%m%d_%H%M%S).sql.gz

注意一下:$(date +%Y%m%d_%H%M%S)    -- 这个是用于生成时间信息的,注意date后面必须跟一个空格否则日期出不来!这是格式要求。

而且这里面我们使用了压缩命令,讲备份文件进行了压缩。减少备份文件的体积。

 

posted @ 2017-09-18 18:23  入得风云,经得风吹  阅读(189)  评论(0编辑  收藏  举报