一、利用crond实现一个定时任务

        在LINUX中,周期执行的任务一般由cron这个守护进程来处理[ps -ef|grep cron]。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。
cron的配置文件称为“crontab”,是“cron table”的简写。 

crontab支持两种状态:

a.直接编写计划任务;

b.使用目录的方式,放在目录里面的都会定时执行,定时目录可在/etc/crontab中设定。

为当前用户创建cron服务

1.  键入 crontab  -e 编辑crontab服务文件

cron文件语法:

      分       小时     日        月        星期      命令

      0-59   0-23    1-31    1-12      0-6     command     (取值范围,0表示周日一般一行对应一个任务)

     记住几个特殊符号的含义:

         “*”代表取值范围内的数字

         “/”代表”每”,

         “-”代表从某个数字到某个数字,

         “,”分开几个离散的数字

      例如 文件内容如下:

      */1 * * * *echo "it's dinner time">> /home/admin/abc.txt

     */2 * * * * /bin/sh /home/admin/jiaoben/deleteFile.sh 

      /bin/sh /home/admin/jiaoben/buy/deleteFile.sh 这一字段可以设定你要执行的脚本,这里

要注意一下bin/sh 是指运行脚本的命令 ,后面一段时指脚本存放的路径。

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

3.cron是一个linux下 的定时执行工具,可以在无需人工干预的情况下运行作业。

  /sbin/service crond start    //启动服务
  /sbin/service crond stop     //关闭服务
  /sbin/service crond restart  //重启服务
  /sbin/service crond reload   //重新载入配置
  /sbin/service crond status   //查看服务状态 

4. 查看服务是否已经运行用 ps -ax | grep cron 

5. 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命令每分钟会定期检查是否有要执行的工作,如果有要执行的工作便会自动执行该工作.

5、权限问题

crontab权限问题到/var/adm/cron/下一看,文件cron.allow和cron.deny是否存在
用法如下: 
1)、如果两个文件都不存在,则只有root用户才能使用crontab命令。 
2)、如果cron.allow存在但cron.deny不存在,则只有列在cron.allow文件里的用户才能使用crontab命令,如果root用户也不在里面,则root用户也不能使用crontab。 
3)、如果cron.allow不存在, cron.deny存在,则只有列在cron.deny文件里面的用户不能使用crontab命令,其它用户都能使用。 
4)、如果两个文件都存在,则列在cron.allow文件中而且没有列在cron.deny中的用户可以使用crontab,如果两个文件中都有同一个用户,
以cron.allow文件里面是否有该用户为准,如果cron.allow中有该用户,则可以使用crontab命令。

 例如:每隔一分钟:

wKioL1cxx2zjk_sZAAASF8XZBpM865.jpg

用tail -f abc1.txt监视便会得到如下结果,完成了一个简单的定时任务:

wKioL1cxx2zhjwjAAAAd1e4BAI0959.jpg

注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。

6. 任务调度设置文件的写法

      1) 在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。

      2)直接编辑/etc/crontab 文件,即vi /etc/crontab,添加相应的任务

     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”这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而

不是文件夹名了


二、守护进程

    守护进程也称精灵进程(Daemon),是运行在后台的一种特殊进程。它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件。守护进程是一种很有用的进程。

Linux的打多数服务器就是用守护进程实现的。如,Internet服务器inetd,Web服务器httpd等。同时,守护进程完成许多系统任务。如,作业规划进程crond等。

Linux系统启动时会启动很多系统服务进程,例如“网络登录过程”中的inetd,这些系统服务进程没有控制终端,不能直接和用户交互。其它进程都是在用户登录或运行程序时创建,在运行结束或用户注销时终止,但系统服务进程不受用户登录注销的影响,它们一直在运行着。这种进程有一个名称叫守护进程(Daemon)。  

我们可以用ps axj命令查看系统中的进程。参数a表示不仅列出当前用户的进程,也列出所有其他用户的进程,参数x表示不仅列有控制终端的进程,也列出所有无控制终端的进程,参数j表示列出与作业控制相关的信息。

wKiom1cxyIKjceKxAABkUceku2w687.jpg


凡是TPGID一栏写着-1的都是没有控制终端的进程,也就是守护进程。在COMMAND一列[]括起来的名字表内核线程,这些线程在内核里创建,没有用户空间代码,因此没有程序文件名和命令行, 通常采用以k开头的名字,表示Kernel。init进程我们已经很熟悉了,udevd负责维护/dev目录下的设备文件,acpid负责电源管理,syslogd负责维护/var/log下的日志文件,可以看出,守护进程通常采用以d结尾的名字,表Daemon。


创建守护进程最关键的一步是调用setsid函数创建一个新的Session,并成为Session Leader。


该函数调用成功时返回新创建的Session的id(其实也就是当前进程的id),出错返回-1。注意,调用这个函数之前,当前进程不允许是进程组的Leader,否则该函数返回-1。要保证当前进程不是进程组的Leader也很容易,只要先fork再调用setsid就行了。fork创建的子进程和父进程在同一个进程组中,进程组Leader必然是该组的第一个进程,所以子进程不可能是该组的第一个进程,在子进程中调用setsid就不会有问题了。  

成功调用该函数的结果是:

1. 创建一个新的Session,当前进程成为Session Leader,当前进程的id就是Session的id。

2. 创建一个新的进程组,当前进程成为进程组的Leader,当前进程的id就是进程组的id。

3. 如果当前进程原本有一个控制终端,则它失去这个控制终端,成为一个没有控制终端的进程。所谓失去控制终端是指,原来的控制终端仍然是打开的,仍然可以读写,但只是一个普通的打开文件而不是控制终端了。

创建守护进程  

1. 调用umask将文件模式创建屏蔽字设置为0.

2. 调用fork,父进程退出(exit)。原因:1)如果该守护进程是作为一条简单的shell命令启动的,那么么进程终止使得shell认为该命令已经执行完毕。2)保证子进程不是一个进程组的组长进程。

3. 调用setsid创建一个新会话。setsid会导致:1)调用进程成为新会话的首进程。 2)调用进程成为一个进程组的组长进程 。3)调用进程没有控制终端。(再次fork一次,保证daemon进程,之后不会打开tty设备)

4. 将当前工作目录更改为根目录。

5. 关闭不在需要的文件描述符。

6. 其他:忽略SIGCHLD信号

例:

wKiom1cxyVCTfQR9AACJWQCeEDQ080.jpg

wKioL1cxyi6isV7gAAA87F-nyhY124.jpgwKioL1cxyYSzjTdhAAAcPNlJBz0395.jpg

wKioL1cxyYSjkIgoAAAKcOVqFbM040.jpg

运行结果:

wKiom1cxyKbzffZ3AAAaqT3Aw-c264.jpg