什么是例行性命令?
每个人或多或少都有一些约会或者是工作,有的工作是例行性的,例如每年一次的加薪、每个月一次的工作报告、每周一次的午餐会报、每天需要的打卡等等;有的工作则是临时发生的,例如刚好总公司有高官来访,需要你准备演讲器材等等!用在生活上面,例如每年的爱人的生日、每天的起床时间等等、还有突发性的电脑大降价(阿~我等好久了~~)等等啰。这些工作都可以称为例行性命令,而这些工作 Linux 也都可以帮您提醒,例如:每一天早上 8:00 钟要伺服器连接上音响,并启动音乐来唤你起床;而中午 12:00 希望 Linux 可以发一封信到你的邮件信箱,提醒你可以去吃午餐了;另外,在每年的你爱人的生日的前一天,先发封信提醒你,以免忘记这么重要的一天。
从上面的说明当中可以很清楚的发现两种工作排程的方式:
· 一种是例行性的,就是每隔一定的周期要来办的事项;
· 一种是突发性的,就是这次做完以后就没有的那一种(电脑大降价....)
那么在 Linux 底下如何达到这两个功能呢?呵呵!那就得使用 at 与 crontab 这两个好东西啰!
· at : 这个工作仅执行一次就从 Linux 系统中的排程中取消;
· crontab : 这个工作将持续例行性的作下去!
底下我们先来谈一谈 Linux 的系统到底在做什么事情,怎么有若干多的工作排程在工作呢?然后再回来谈一谈 at 与 crontab 这两个好东西!
Linux 系统的例行性命令有哪些
好了,那么伺服器自己有什么例行性命令要来作呀!?Linux 的工作可多着呢!由前面提到的几篇文章中,我们知道Linux 本身在背景下的工作可是很多的,尤其是网路开放的情况下,建立与取消连线、MySQL 资料库的即时更新、以及一些例行的系统指令,例如释放记忆体的工作等等。由于例行的工作非常的多,实在不可能每天都要管理员来手动输入吧!所以才会建立这个工作排程的需求的!基本预设的工作有底下这些:
· 进行资料轮替 ( log rotate ):这个步骤重要了!尤其是在 log file 的选项当中!由于登录档案会越来越大,所以需要适时适量的将登录档备份,并以新开的档案来进行记录,这样效率会比较好,因此就需要使用 log rotate 啦!系统预设的重要工作之一;
· rpm 资料库的建立:虽然 RPM 资料库会在你以 RPM 安装之后即更新到 RPM 资料库当中去,但是难保会有漏网之鱼,所以系统也会设定每隔依段时间自动的搜集系统上面的 RPM 资料库来建置一番;
· 建立 locate 的资料库:是否还记得为何使用 locate 这个指令时,搜寻速度超快!那是因为 Linux 系统上将档案与路径都记录在资料库里面了!所以使用 locate 的时候,嘿嘿!直接指向资料库去 ( /var/lib/slocate/slocate.db ) ,偏偏麻烦的是这个档案的更新是每天一次!所以当你今天更新的档案,使用 locate 反而可能会找不到....
· 进行程序的分析:每隔依段时间会进行程序的分析,如果发现有僵尸程序的时候,就会将他删去!以保持记忆体的工作能力!
· 登录档视察:这个东西是在 Red Hat 7.1 以后才出现的东西,后来太好用了,所以被拿到旧版的 Red Hat 里面去使用!基本上就是分析登录档啦!然后据以解析有问题的纪录档,以维护主机的安全性!这部份不才小弟也自己写了一个简易型的分析档案,觉得更好用就是了!
· 指纹资料库的比对:基本上就是 tripwire 这个套件啦!可以用来分析最近被更动过的档案内容!蛮不错的一个程式!有空也来玩玩看。
Linux 预设的例行工作至少就有这些了,再加上您努力的为 Linux 进行工作排程的设计,嘿嘿!每天的工作量可是相当的大的呢!
仅执行一次的工作排程
如果仅要执行一次的工作,就使用 at 这个指令吧!这个指令其实就是 atd 这个服务啦!所以请记得一定要启动这个服务呦!
1. ntsysv
2. 选择 atd
3. 按下 OK !
基本上, atd 是预设开启的,如果您没有更动过系统预设值的话,那么上面的动作就不需要动啰!下达 at 这个动作会将工作排程写入 /var/spool/at 这个目录下呢!然后等待系统将之执行啰!此外,这个 at 指令虽然预设是所有人都能进行,但是可以经由 root 的规范来限制使用的人口。限制的方法其实与 /etc/hosts.allow(deny) 类似,使用 /etc/at.allow(deny) 这两个档案来限制:
· 限制使用者原理:当使用者执行 at 时,系统会
1. 先找寻 /etc/at.allow 这个档案,写在这个档案中的使用者才能使用 at ,没有在这个档案中的使用者则不能使用 at ( 即使没有写在 at.deny 当中 );
2. 如果没有 /etc/at.allow 就寻找 /etc/at.deny 这个档案,若写在这个 at.deny 的使用者则不能使用 at ,而没有在这个 at.deny 档案中的使用者,就可以使用 at 咯;
3. 如果两个档案都不存在,那么只有 root 可以使用 at 这个指令。
· Red Hat 预设情况下,只有 /etc/at.deny 这个档案,且这个档案的内容为空白的,由于内容没有任何使用者,所以当然『所有人都可以使用 at 』
· 如果不想要某个使用者使用 at 时,那么将该使用者帐号写到 /etc/at.deny 这个档案中即可。
好了!我们来谈一谈 at 的语法吧!
[test @test test]# at [-m] TIME (下达工作指令) [test @test test]# atq (查看目前的工作排程) [test @test test]# atrm [jobnumber] (删除排程) 参数说明: -m :执行 at 所规范的工作排程时,将萤幕输出结果 mail 给下达指令的使用者 TIME :时间的格式,有底下几个: HH:MM YYYY-MM-DD ex> 04:00 2002-05-30 (五月三十号四点执行) HH[pm;am] + number [hours;days;weeks] ex> 4pm + 3 days (在过 3 天的下午 4 点) HH:MM ex> 12:00 (今天的 12 点执行) HH[pm;am] [Month] [Day] ex> 1pm May 30 jobnumber:每一个 at 工作排程都有编排的顺序!这个即是! 范例: [test @test test]# at 5pm <==在今天的 5pm 执行,如果今天已过 5 点则明天执行; warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh at> mail -s test test < /home/test/.bashrc <==这就是我的工作! at> <==这里是按下 [Ctrl] + D 就可以离开了! job 8 at 2002-05-30 17:00 <==这里会告诉你这个工作的号码为 8 号,执行的日期为后面所示。 [test @test test]# atq <==窥视一下你(test)目前有多少工作? 5 2002-05-30 12:00 a test 8 2002-05-30 17:00 a rest [test @test test]# atrm 5 <==删除第 5 号工作 [test @test test]# atq 8 2002-05-30 17:00 a rest
请注意!在 at 下达之后,便进入指令列下达的模式!在这里你可以重复的输入指令,但是离开的时候请下达『 [Ctrl] + D 』就可以离开了!离开之后,系统会告诉你这个工作排程的号码与使用者是谁!呵呵!很简单吧!