1、计划任务考释;

计划任务,是任务在约定的时间执行早已计划好的工作,这是表面的意思。在Linux中,我们常常用到 crond 服务器来完成这项工作。cron服务器可以按照配置文件约定的时间来执行特定的作务。比如我们可以在配置文件中约定每晚早上4点,对httpd 服务器重新启动,这就是一个计划任务;

下面我们先来谈谈cron;

2、cron;

Linux中,计划任务通常是由cron承当,我们可以把cron设置为开机时手动启动。cron启动后,它会读取它的所有配置文件(全局性配置文件/etc/crontab,以及每位用户的计划任务配置文件),然后cron会按照和执行时间来按量来调用度工作任务。

2.1 cron 的安装和启动;

在通常情况下linux学习,cron都是系统默认安装的,我们要学会查看软件包是否早已安装;

2.1.1 在Redhat 或 Fedora等RPM包管理的系统的安装;

判断系统是否早已安装cron相关的包

Fedora 5.0 系统的情况;

其它版本的Fedora及Redhat的系统和这相像;

[root@localhost ~]# rpm -qa |grep cron

vixie-cron-4.1-54.FC5

anacron-2.3-36.1

crontabs-1.10-7.1

其中vixie-cron软件包是cron的主程序,您可以通过下边的来了解它,其它软件包同理;

[root@localhost beinan]# rpm -ql vixie-cron

crontabs 软件包是拿来安装、卸装、或列出拿来驱动 cron 守护进程的表格的程序。cron 守护进程检测 crontab 文件来查看某个指定被调度执行的时间。如果命令已然调度,守护进程都会执行它们。了解crontabs软件包都安装了些哪些,应该用下边的命令;

[root@localhost beinan]# rpm -ql crontabs

如果没有安装,可以从光碟中找出文件名带有cron字样的软件包来安装。

[root@localhost ~]# rpm -ivh vixie-cron-4.1-54.FC5*

[root@localhost ~]# rpm -ivh crontabs*

也可以用yum 来在线安装;

[root@localhost ~]# yum install vixie-cron

[root@localhost ~]# yum install crontabs

2.1.2 在Slackware系统中的安装;

在Slackware中cron软件包是 dcron,您可以在光碟中找下来安装它;

查看是否早已安装了dcron软件包,您可以这样查看。在这儿能列举软件包详尽的安装情况;

[root@localhost ~]# more /var/adm/packages/dcron*

捕快任务没任务显示_linux定时执行_linux 计划任务没执行

如果没有安装,请用下边的命令来安装。在第一张安装盘中找出dcron软件包;

[root@localhost ~]# installpkg dcron*.tgz

2.1.3 cron 的开启、停止、重新启动方式;

cron配置文件被更改后,想让新文件生效,必须重新crond服务器,有两种方式可供选择;

第一种 在Fedora或Redhat 等以RPM包管理的系统中;

[root@localhost ~]# /etc/init.d/crond start

[root@localhost ~]# /etc/init.d/crond stop

[root@localhost ~]# /etc/init.d/crond restart

如果想在Fedora 和 Redhat 或以这种发行版为基础克隆的发行版,如果想手动开机运行,请用下边的办法;

[root@localhost ~]# chkconfig --levels 35 crond on

第二种:通用

[root@localhost ~]# pgrep crond 注:判断crond 是否在运行;

[root@localhost ~]# pkill crond 注:杀掉正在运行中的crond;

[root@localhost ~]# pgrep crond 注:查看是否被杀掉了;

[root@localhost ~]# /usr/sbin/crond 注:运行crond;

2.2 cron 配置文件;

cron 是一个服务器程序,我们都晓得Linux的服务器的配置,大多是通过配置文件来完成的,cron自然也不例外,在Redhat/Fedora 等系统中它的全局性配置文件是/etc/crontab;在Slackware系统中,全局性文件是 /var/spool/cron/crontabs/root 。每个用户也有自己的cron配置文件,我们可以通过crontab -e 来编辑它;

2.2.1 全局性配置文件;

下面是一个全局性的配置文件事例,以Fedora Core 5为例;

[root@localhost ~]# more /etc/crontab

=/bin/bash

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root

HOME=/

# run-parts

1 * * * * root run-parts /etc/cron.hourly

2 4 * * * root run-parts /etc/cron.daily

捕快任务没任务显示_linux定时执行_linux 计划任务没执行

22 4 * * 7 root run-parts /etc/cron.weekly

42 4 1 * * root run-parts /etc/cron.monthly

0,5,10,15,20,25,30,35,40,45,50,55 * * * * root /usr/bin/mrtg /etc/mrtg/mrtg.cfg

对于全局性配置文件,我们要用root权限来修改,一般是通过crontab -e 来更改。但有时也并不一定是这样的,比如Fedora Core 5 如果通过crontab -e 修改的是root用户的cron 配置文件。所以我们要在Fedora Core 5中更改全局性配置文件可以用vi 编辑器来更改。vi的用法请参考:《文件编辑器 vi》

在全局性配置文件中,定义了可执行命令的路径环境变量,所用SHELL类型的定义等,这些大多不用更改;我们常常添加的是计划任务或更改任务执行的时间等;

在全局性配置文件中,我们发觉有类似这种行;

1 * * * * root run-parts /etc/cron.hourly 注:表示每个小时的第一分钟,开始执行/etc/hourly目录下的可执行程序或;

2 4 * * * root run-parts /etc/cron.daily 注:表示每晚的4点2分,开始执行/etc/cron.daily目录下的可执行程序或;

22 4 * * 7 root run-parts /etc/cron.weekly 注:每年第7个周4点我22分,开始执行 /etc/cron.weekly目录下的可执行程序或脚本;

42 4 1 * * root run-parts /etc/cron.monthly 注:每月第1天的4点42分,开始执行/etc/cron.monthly目录下的可执行程序或脚本;

这些行是拿来在同一时间批量执行任务的,我们在之后的事例中独立下来解说,在这儿只是让你们心中有数;

2.2.2 cron 配置计划任务的书写格式

分钟 小时 日 月 周 [用户名] 命令

说明:

第一段应当定义的是:分钟,表示每个小时的第几分钟来执行。范围是从0-59

第二段应当定义的是:小时,表示从第几个小时来执行,范围是从0-23

第三段应当定义的是:日期,表示从每个月的第几天执行,范围从1-31

第四段应当定义的是:月,表示每年的第几个月来执行,范围从1-12

第五段应当定义的是:周,表示每周的第几天执行,范围从0-6,其中 0表示星期日。

每六段应当定义的是:用户名,也就是执行程序要通过那个用户来执行,这个通常可以省略;

第七段应当定义的是:执行的命令和参数。

注:其中用户名而且省略,用户名定义的是程序用那个用户来执行,比如mysql服务器,我们可以定义成以mysql用户来启动、停止、重新启动,这时要写上用户名;不过对于cron来说意义不是太大,因为每位用户都有自己的cron配置文件。有些程序的启动必须用到root用户,这时我们就可以更改root用户的cron配置文件就行了。在每位用户的配置文件中,不必指定用户名。

我们可以把计划任务写在全局性配置文件中,如果您想把一个计划装入全局性配置文件中,就得改发行版所对应的cron全局配置文件,比如Fedora 5的全局性配置文件是/etc/crontab文件;

每个用户也能定义自己的cron配置文件,用crontab -e 命令来定义;

举一例:让机器在每晚8点30分重新启动;

关于时间格式中有7个数组。我们可以直接修改或则添加,当然这是系统任务调用。举个事例linux 计划任务没执行,比如我在每晚的早上8点30分重新启动机器,就可以在

/etc/crontab中加入下边的两句,第一句就是注释了。以#号开始,后面写一个自己能晓得这是哪些任务的备注;

# reboot OS

30 8 * * * root /sbin/reboot

第一段应当定义的是:分钟,表示每个小时的第几分钟来执行。范围是从0-59

第二段应当定义的是:小时,表示从第几个小时来执行,范围是从0-23

第三段应当定义的是:日期,表示从每个月的第几天执行,范围从1-31

第四段应当定义的是:月,表示每年的第几个月来执行,范围从1-12

第五段应当定义的是:周,表示每周的第几天执行,范围从0-6,其中 0表示星期日。

每六段应当定义的是:用户名,也就是执行程序要通过那个用户来执行,这个通常可以省略;

第七段应当定义的是:执行的命令和参数。

对比前面的反例就晓得,30是不是分钟??8是不是小时?如果有*代表的地方,表示全部,也就是说,每个月,每天,每星期都要执行。root 表示用root用户执行,命令是/sbin/reboot ,也就是说,系统在每晚 8点30分重新启动;

我们可以把每晚8点30分重新启动的计划任务写入cron全局性配置文件中,也可以定义在root用户自己的cron配置文件中。如果定义在 root自己的配置文件,请用root身分来执行 crontab -e 来更改配置文件;crontab -e 进入更改配置文件的过程,其实和vi的用法一样,请参看vi 的用法:《文件编辑器 vi》

让配置文件生效:如果让配置文件生效,还得重新启动cron,切记,既然每位用户下的cron配置文件更改后。也要重新启动cron服务器。

在Fedora 和Redhat中,我们应当用;

[root@localhost ~]# /etc/init.d/crond restart

如果让crond 在开机时运行,应该改变其运行级别;

[root@localhost ~]# chkconfig --levels 35 crond on

在Slackware中,如果开机手动运行;

查看/etc/rc.d/rc.M文件是否有如的行,如果没有就加上,大多是有的;

# Start crond (Dillon's crond):

if [ -x /usr/sbin/crond ]; then

/usr/sbin/crond -l10 >>/var/log/cron 2>&1

如果想让立刻让cron重启生效,也可以用下边的办法;

[root@localhost ~]# pgrep crond 注:查看crond服务器是否运行;

2022

[root@localhost ~]# pkill crond 注:杀死crond;

[root@localhost ~]# pgrep crond 注:查看crond是否退出;

[root@localhost ~]# /usr/sbin/crond 注:启动crond;

[root@localhost ~]# pgrep crond 注:查看crond 是否早已运行得上去了;

3883

2.2.3 关于同一时间,同时执行多个任务的定义方式;

我们在后面早已说过,在全局性配置文件中,有类似如下的段落;

1 * * * * root run-parts /etc/cron.hourly 注:表示每个小时的第一分钟,开始执行/etc/hourly目录下的可执行程序或脚本;

2 4 * * * root run-parts /etc/cron.daily 注:表示每晚的4点2分,开始执行/etc/cron.daily目录下的可执行程序或脚本;

22 4 * * 7 root run-parts /etc/cron.weekly 注:每年第7个周4点我22分,开始执行 /etc/cron.weekly目录下的可执行程序或脚本;

42 4 1 * * root run-parts /etc/cron.monthly 注:每月第1天的4点42分,开始执行/etc/cron.monthly目录下的可执行程序或脚本;

举例来说,我想在每晚5点10分来重新启动httpd 服务器,与此同时,我们也可以同时下载一个ISO文件。如果我们按书写计划任务的规则一条一条的来书写,并添加到全局是有点麻烦。不如写一个脚本置于 /etc/crond.daily目录中。然后把其权限设置为755 (关于权限的设置,请参考:《Linux 文件和目录的属性》)。

当然我们得改一改里面的 带有/etc/cron.daily那行,改为如下;

10 5 * * * root run-parts /etc/cron.daily

然后我们到/etc/crond.daily目录中创建两个文件,一个是拿来重启httpd服务器的,如下;

[root@localhost cron.daily]# touch httpd.sh

[root@localhost cron.daily]# chmod 755 httpd.sh

[root@localhost cron.daily]# echo "/etc/init.d/httpd restart" > httpd.sh

[root@localhost cron.daily]# more httpd.sh

/etc/init.d/httpd restart

如果我想在每晚5点20分下载FC5的镜像,可以再创建一个文件fc5down.sh

[root@localhost cron.daily]# touch fc5down.sh

[root@localhost cron.daily]# chmod 755 fc5down.sh

[root@localhost cron.daily]# echo "/usr/bin/wget " > fc5down.sh

[root@localhost cron.daily]# more fc5down.sh

/usr/bin/wget

然后我们重新启动一下crond就行了;

[root@localhost cron.daily]# pkill crond

[root@localhost cron.daily]# prep crond

[root@localhost cron.daily]# crond&

linux定时执行_linux 计划任务没执行_捕快任务没任务显示

注意:我只是想说明一下,在同一时间执行多个计划任务的简单用法,并不是有意教给您每晚晚上都下载FC5的映像。我举这个事例是为了初学者了解这个功能。如果您有很多的任务在某一时刻执行,那就自己写脚本文件。放在/etc目录下的cron.hourly 、cron.daily 、cron.weekly 、cron.monthly 目录中。凡是放进这种目录的可执行脚本,都能在约定的时间内确切执行。每个目录有每位目录的用途;

2.2.4 对于用户自身的cron 配置文件的说明;

每个用户都有自己的cron配置文件linux 计划任务没执行,通过crontab -e 就可以编辑,一般的情况下,在Fedora和Redhat的发行版,我们编辑好用户的cron配置文件保存退出后,系统会手动就储存于 /var/spool/cron/目录中,文件以用户名命名。在Slackware中是坐落/var/spool/cron/crontabs/目录中。其它的发行版都差不多,有点类似。自己找找吧;查看用户的计划任务是crontab -l

crontab -e 注:编辑用户的cron配置文件;

crontab -l 注:查看用户的计划任务;

比如我用beinan用户来运行crontab -e ;

[beinan@localhost ~]$ id 注:判断所用用户身分;

uid=500(beinan) gid=500(beinan) groups=500(beinan)

[beinan@localhost ~]$ crontab -e 注:编辑用户beinan的计划任务;

我们在上面定义一个任务;

40 20 * * * /usr/bin/wget

保存退出后,我们用下边的命令来查看beinan用户的计划任务;

[beinan@localhost ~]$ crontab -l

40 20 * * * /usr/bin/wget

配置好后,我们还要重新启动crond服务器linux操作系统教程,每个用户cron配置文件的改动都得重新启动crond服务器;前面早已说过了,这里省略;值得注意的是重启crond服务器,需要root权限,您可以用su命令切换到root 用户,然后再来重启crond;

在Fedora或Redhat等以RPM包管理的发行版中;

[beinan@localhost ~]$ su

口令:

[root@localhost beinan]# /etc/init.d/crond restart

停止 crond: [确定]

启动 crond: [确定]

也可以先杀害crond,再运行crond命令的办法来启动;

[root@localhost beinan]# pkill crond

[root@localhost beinan]# pgrep crond

[root@localhost beinan]# /usr/sbin/crond

[root@localhost beinan]# pgrep crond

6664

3、计划任务的应用范围;

计划任务主要是让系统手动完成一些工作。比如我们可以让系统手动在某一时刻清除或备份httpd服务器的日志,然后重新启动httpd服务器,这对网络管理员来说是很重要的。也可以让系统手动清空坐落/tmp目录的垃圾文件。

本文原创地址://q13zd.cn/ljhrwrj.html编辑:刘遄,审核员:暂无