以梦为马不负韶华 2014-03-06
在oracle中可以利用dbms_job包定时执行pl/sql、sql过程,在像备份等需要在操作系统级定时任务只能采用crontab来完成
本文讲述crontab具体用法,以供备忘.
在oracle中可以利用dbms_job包定时执行pl/sql、sql过程,在像备份等需要在操作系统级定时任务只能采用crontab来完成
利用crontab来定时执行任务大致有如下三步:
1、编写shell脚本
2、利用crontab加入到定时任务队列
3、查看作业完成情况
一、如何建立shell脚本
Linux下有很多不同的shell,但我们通常使用bash(bourneagainshell)进行编程,因为bash是免费的并且很容易使用
程序必须以下面的行开始(必须方在文件的第一行):
#!/bin/sh
符号#!用来告诉系统它后面的参数是用来执行该文件的程序。在这个例子中我们使用/bin/sh来执行程序。
当编辑好脚本时,要想执行脚本,必须使脚本可以执行
下面的命令,可以使脚本可以执行
chmod+xfilename
然后可以输入./filename来执行脚本。
注:在shell编程时,#符号表示注释,只该行结束为止。在编写程序时,最好使用注释。
变量
shell下所有变量都以字符串表示,变量不需要声明,直接使用。直接对变量进行赋值
A="helloworld"
取出变量用$符号,如:
#!/bin/sh
A="helloworld"
echo"Ais:"
echo$A
执行该脚本输出结果如下:
Ais:
helloworld
shell命令和流程控制
1)unix命令
在shell中可以使用任意的unix命令,但这里介绍一些更常用的unix命令
echo''thisisaexample":打印输出到屏幕
ls:列出文件列表
cpsourcefiledestinationfile:拷贝文件
2)概念:管道,重定向和backtick
这些不是系统命令,但他们经常使用,很重要的
管道|将一个命令的输出作为另外一个命令的输入
grep-qacompat|more
重定向:将命令的结果输出到文件,而不是标准输出(屏幕)
〉写入文件并覆盖旧文件
〉〉输出追加到文件的尾部,保留旧文件。
3)流程控制
if...;then
...
elseif...;then
...
else
...
fi
通常情况下,可以通过测试命令来对条件进行测试,比如可以比较字符串,判断文件是否存在及是否有执行权限等等
通常用“[]“来表示条件测试,注意这里空格很重要,要确保方括号空格
[-f"somefile"]:判断是否是一个文件
[-x"/bin/ls"]:判断/bin/ls是否存在并有可执行权限
[-n"$var"]:判断$var变量是否有值
["$a"="$b"]:判断$a和$b是否相等
实例 一般编程步骤
任何优秀的脚本都应该有帮助和输入参数,并且写一个伪脚本framework.sh,该脚本包含了大多数脚本都需要的框架结构。
是个非常不错的注意。这时候,我们编写脚本时只需要执行cp命令即可
cpframework.shmyscript
然后插入自己需要的函数就可以了
调试
最简单的调试命令当然是使用echo命令。您可以使用echo在任何怀疑出错的地方打印任何变量值。这也是绝大多数的shell程序员要花费80%的时间来调试程序的原因。Shell程序的好处在于不需要重新编译,插入一个echo命令也不需要多少时间。
shell也有一个真实的调试模式。如果在脚本"strangescript"中有错误,您可以这样来进行调试:
sh-xstrangescript
这将执行该脚本并显示所有变量的值。
shell还有一个不需要执行脚本只是检查语法的模式。可以这样使用:
sh-nyour_script
这将返回所有语法错误。
RedhatlinuxAS3下定时执行任务
二、cron调度进程
cron是系统主要的调度进程,可以在无需人工干预的情况下运行作业。有一个叫做
crontab的命令允许用户提交、编辑或删除相应的作业。每一个用户都可以有一个crontab文件
来保存调度信息。可以使用它运行任意一个shell脚本或某个命令,每小时运行一次,或一周
三次,这完全取决于你。每一个用户都可以有自己的crontab文件,但在一个较大的系统中,
系统管理员一般会禁止这些文件,而只在整个系统保留一个这样的文件。系统管理员是通过
cron.deny和cron.allow这两个文件来禁止或允许用户拥有自己的crontab文件。
3.1.1crontab的域
为了能够在特定的时间运行作业,需要了解crontab文件每个条目中各个域的意义和格式。
下面就是这些域:
第1列分钟1~59
第2列小时1~23(0表示子夜)
第3列日1~31
第4列月1~12
第5列星期0~6(0表示星期天)
第6列要运行的命令
crontab的范例格式:
下面是crontab的格式:
分<>时<>日<>月<>星期<>要运行的命令
其中<>表示空格。
Crontab文件的一个条目是从左边读起的,第一列是分,最后一列是要运行的命令,它位
于星期的后面。
在这些域中,可以用横杠-来表示一个时间范围,例如你希望星期一至星期五运行某个作
业,那么可以在星期域使用1-5来表示。还可以在这些域中使用逗号“,”,例如你希望星期一
和星期四运行某个作业,只需要使用1,4来表示。可以用星号*来表示连续的时间段。如果你
对某个表示时间的域没有特别的限定,也应该在该域填入*。该文件的每一个条目必须含有5
个时间域,而且每个域之间要用空格分隔。该文件中所有的注释行要在行首用#来表示。
crontab条目举例
这里有crontab文件条目的一些例子:
3021***/apps/bin/cleanup.sh
上面的例子表示每晚的21:30运行/apps/bin目录下的cleanup.sh。
4541,10,22**/apps/bin/backup.sh
上面的例子表示每月1、10、22日的4:45运行/apps/bin目录下的backup.sh。
101**6,0/bin/find-name"core"-execrm{};
上面的例子表示每周六、周日的1:10运行一个find命令。
0,3018-23***/apps/bin/dbcheck.sh
上面的例子表示在每天18:00至23:00之间每隔30分钟运行/apps/bin目录下的dbcheck.sh。
023**6/apps/bin/qtrend.sh
上面的例子表示每星期六的11:00pm运行/apps/bin目录下的qtrend.sh。
你可能已经注意到上面的例子中,每个命令都给出了绝对路径。当使用crontab运行shell
脚本时,要由用户来给出脚本的绝对路径,设置相应的环境变量。记住,既然是用户向cron
提交了这些作业,就要向cron提供所需的全部环境。不要假定cron知道所需要的特殊环境,它
其实并不知道。所以你要保证在shell脚本中提供所有必要的路径和环境变量,除了一些自动
设置的全局变量。
命令形式:
crontab命令的一般形式为:
Crontab[-uuser]-e-l-r
其中:
-u用户名。
-e编辑crontab文件。
-l列出crontab文件中的内容。
-r删除crontab文件。
如果使用自己的名字登录,就不用使用-u选项,因为在执行crontab命令时,该命令能够
知道当前的用户
建一个新的crontab文件
在考虑向cron进程提交一个crontab文件之前,首先要做的一件事情就是设置环境变量
EDITOR。cron进程根据它来确定使用哪个编辑器编辑crontab文件。99%的UNIX和LINUX用
户都使用vi,如果你也是这样,那么你就编辑$HOME目录下的.profile文件,在其中加入这样
一行:
EDITOR=vi;exportEDITOR
然后保存并退出。
不妨创建一个名为<user>cron的文件,其中<user>是用户名,例如,jamescron。在该文件中加入如下的内容。
#。。。。这里是解释的话
0,15,30,4518-06***/bin/echo'time'>/dev/console
保存并退出。确信前面5个域用空格分隔。
在上面的例子中,系统将每隔15分钟向控制台输出一次当前时间。如果系统崩溃或挂起,
从最后所显示的时间就可以一眼看出系统是什么时间停止工作的。在有些系统中,用tty1来表
示控制台,可以根据实际情况对上面的例子进行相应的修改。
为了提交你刚刚创建的crontab文件,可以把这个新创建的文件作为cron命令的参数:
$crontabjamescron
现在该文件已经提交给cron进程,它将每隔15分钟运行一次。
同时,新创建文件的一个副本已经被放在/var/spool/cron目录中,文件名就是用户名(即,
james)。
列出crontab文件:
为了列出crontab文件,可以用:
你将会看到和上面类似的内容。可以使用这种方法在$HOME目录中对crontab文件做一备
份:
$crontab-l>$HOME/mycron
这样,一旦不小心误删了crontab文件,可以用上一节所讲述的方法迅速恢复。
编辑crontab文件:
如果希望添加、删除或编辑crontab文件中的条目,而EDITOR环境变量又设置为vi,那么
就可以用vi来编辑crontab文件,相应的命令为:
$crontab-e
可以像使用vi编辑其他任何文件那样修改crontab文件并退出。如果修改了某些条目或添加了新的条目,那么在保存该文件时,cron会对其进行必要的完整性检查。如果其中的某个域出现了超出允许范围的值,它会提示你。
保存并退出。最好在crontab文件的每一个条目之上加入一条注释,这样就可以知道
它的功能、运行时间,更为重要的是,知道这是哪位用户的作业。
可以使用前面讲过的crontab-l命令列出它的全部信息
为了删除crontab文件,可以用:
$crontab-r
三,可以利用重定向命令来输出运行结果
>,>>
四、具体实例
sh脚本文件:test.sh
#!/bin/sh
su-oracle<<EOF
sqlplustest/test@test@"test.sql"
sql脚本文件:test.sql
insertintotest_tbvalues(sysdate);
crontab文件:
0,15,30,45****/apps/bin/test.sh