在Unix中也有计划任务,下面是详细介绍:
crontab [-u user] -e -l -r 其中:
-u 用户名。如果使用自己的名字登录,就不用使用-u选项。
-e 编辑crontab文件。不带-u选项可以编辑自己的crontab文件。
-l 列出crontab文件中的内容。不带-u选项可以列出自己的crontab文件的内容。
-r 删除crontab文件。小心使用哦。
第1列分钟1~59
第2列小时1~23(0表示子夜)
第3列日1~31
第4列月1~12
第5列星期0~6(0表示星期天)
第6列要运行的命令 例子(注意:提交此命令会覆盖原来的文件,使用之前请做好备份。):
at [-f script] [-m -l -r] [time] [date] 其中,
-f script是所要提交的脚本或命令。
-l 列出当前所有等待运行的作业。atq命令具有相同的作用。
-r 清除作业。为了清除某个作业,还要提供相应的作业标识(ID);有些UNIX变体只接受atrm作为清除命令。
-m 作业完成后给用户发邮件。
time at命令的时间格式非常灵活;可以是H、HH.HHMM、HH:MM或H:M,其中H和M分别是小时和分钟。还可以使用a.m.或p.m.。
date 日期格式可以是月份数或日期数,而且at命令还能够识别诸如today、tomorrow这样
的词。 使用at命令提交作业有几种不同的形式,可以通过命令行方式,也可以使用at命令提示符。 三.&命令 该命令的一般形式为:
命令 &
注意:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。 四.nohup命令 如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用
nohup命令。该命令可以在你退出帐户之后继续运行相应的进程。 该命令的一般形式为:
nohup command & 后台运行命令对于每天都运行的机器很有用,特别是对于我们这些懒的系统维护人员,可以减少我们的工作量,也可以避免某天忘记做什么重要的事情了。
cron
系统调度进程。可以使用它在每天的非高峰负荷时间段运行作业,或在一周或一月中的不同时段运行。(相当有用的一个命令,功能最强大。)At at
命令。使用它在一个特定的时间运行一些特殊的作业,或在晚一些的非负荷高峰时间段或高峰负荷时间段运行。&
使用它在后台运行一个占用时间不长的进程。(大家应该经常用吧。)Nohup
使用它在后台运行一个命令,即使在用户退出(注意这点)时也不受影响。 一.crontab命令crontab
命令的一般形式为:crontab [-u user] -e -l -r 其中:
-u 用户名。如果使用自己的名字登录,就不用使用-u选项。
-e 编辑crontab文件。不带-u选项可以编辑自己的crontab文件。
-l 列出crontab文件中的内容。不带-u选项可以列出自己的crontab文件的内容。
-r 删除crontab文件。小心使用哦。
crontab
文件(各个用户的这个文件放在/var/spool/cron/crontab/目录中,以用户名来区别。) 每个条目中各个域的意义和格式如下。 下面就是这些域:第1列分钟1~59
第2列小时1~23(0表示子夜)
第3列日1~31
第4列月1~12
第5列星期0~6(0表示星期天)
第6列要运行的命令 例子(注意:提交此命令会覆盖原来的文件,使用之前请做好备份。):
30 21* * * /apps/bin/cleanup.sh
上面的例子表示每晚的21:30运行/apps/bin目录下的cleanup.sh。45 4 1,10,22 * * /apps/bin/backup.sh
上面的例子表示每月1、10、22日的4:45运行/apps/bin目录下的backup.sh。10 1 * * 6,0 /bin/find -name "core" -exec rm {} /;
上面的例子表示每周六、周日的1:10运行一个find命令。0,30 18-23 * * * /apps/bin/dbcheck.sh
上面的例子表示在每天18:00至23:00之间每隔30分钟运行/apps/bin目录下的dbcheck .sh。0 23 * * 6 /apps/bin/qtrend.sh
上面的例子表示每星期六的11:00pm运行/apps/bin目录下的qtrend.sh。 既然是用户向cron提交了这些作业,就要向cron提供所需的全部环境。要保证在shell脚本中提供所有必要的路径和环境变量,除了一些自动设置的全局变量。 二.at命令at
命令允许用户向cron守护进程提交作业,使其在稍后的时间运行。如果你希望在一个月或更长的时间以后运行,最好还是使用crontab文件。at
命令的基本形式为:at [-f script] [-m -l -r] [time] [date] 其中,
-f script是所要提交的脚本或命令。
-l 列出当前所有等待运行的作业。atq命令具有相同的作用。
-r 清除作业。为了清除某个作业,还要提供相应的作业标识(ID);有些UNIX变体只接受atrm作为清除命令。
-m 作业完成后给用户发邮件。
time at命令的时间格式非常灵活;可以是H、HH.HHMM、HH:MM或H:M,其中H和M分别是小时和分钟。还可以使用a.m.或p.m.。
date 日期格式可以是月份数或日期数,而且at命令还能够识别诸如today、tomorrow这样
的词。 使用at命令提交作业有几种不同的形式,可以通过命令行方式,也可以使用at命令提示符。 三.&命令 该命令的一般形式为:
命令 &
注意:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。 四.nohup命令 如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用
nohup命令。该命令可以在你退出帐户之后继续运行相应的进程。 该命令的一般形式为:
nohup command & 后台运行命令对于每天都运行的机器很有用,特别是对于我们这些懒的系统维护人员,可以减少我们的工作量,也可以避免某天忘记做什么重要的事情了。
FAQ:
在用crontab -e 时遇到了问题
用crontab -e 编辑要定时启动的事件后,
如何保存退出??
退出后还需做什么工作才能够使用??
如何保存退出??
退出后还需做什么工作才能够使用??
回答:
if your editor is vi .then you can use -e easily.But if default editor is not vi.you should first set it in this way
#EDITOR=vi;export EDITOR
#EDITOR=vi;export EDITOR
写在你的PROFILE文件里面也可以的
脚本不会自动执行,请问哪位知道问题出在哪里?或者还有更好的方法,目的就是要在UNIXWARE7下面让系统自动的进行ORACLE数据备份(逻辑导出)
以下是创建定期任务备份的过程
$ crontab -r
$ crontab -l
UX:crontab: ERROR: Cannot open crontab file: No such file or directory
$ crontab
45 15 * * * /oracle/bakscript/autobak.sh #输入完成后按CTRL+D键退出
UX:crontab: WARNING: Commands will be executed using /usr/bin/sh
$ crontab -l
45 15 * * * /oracle/bakscript/autobak.sh
#!/usr/bin/sh
rq=` date +"%m%d" `
exp scounix/scounix file=/oracle/smart$rq.dmp tables=smart_setup
# echo smart$rq
$
以下是创建定期任务备份的过程
$ crontab -r
$ crontab -l
UX:crontab: ERROR: Cannot open crontab file: No such file or directory
$ crontab
45 15 * * * /oracle/bakscript/autobak.sh #输入完成后按CTRL+D键退出
UX:crontab: WARNING: Commands will be executed using /usr/bin/sh
$ crontab -l
45 15 * * * /oracle/bakscript/autobak.sh
#!/usr/bin/sh
rq=` date +"%m%d" `
exp scounix/scounix file=/oracle/smart$rq.dmp tables=smart_setup
# echo smart$rq
$
直接运行脚本是没有问题的。
$ /oracle/bakscript/autobak.sh
Export: Release 8.1.6.0.0 - Production on 星期五 10月 29 15:44:43 2004
(c) Copyright 1999 Oracle Corporation. All rights reserved.
Connected to: Oracle8i Release 8.1.6.0.0 - Production
JServer Release 8.1.6.0.0 - Production
Export done in ZHS16GBK character set and ZHS16GBK NCHAR character set
About to export specified tables via Conventional Path ...
. . exporting table SMART_SETUP 34 rows exported
Export terminated successfully without warnings.
$
回答:
autobak.sh 中缺少exp执行需要的ORACLE环境变量
crontab教程开天第1小节就讲环境变量需要自己去设置,
cronttab连PATH都不会设置,更不可能自动替你的程序设置你需要的环境变量,
系统不是神仙,它怎么知道你自己的程序需要用什么环境呢?
cronttab连PATH都不会设置,更不可能自动替你的程序设置你需要的环境变量,
系统不是神仙,它怎么知道你自己的程序需要用什么环境呢?