本博文的主要目的是让笔者和读者可以了解并掌握以下内容:
1、Crontab的基本概念
2、Crontab的基本组成
3、操作Crond服务
4、配置系统和用户计划任务
5、监控计划任务日志
在工作中你是否也碰到过这种定时重复的工作呢?
Crontab可以帮助你从这些定时重复的工作中解脱出来
安装并检查crontab服务
– 检查crontab工具是否安装:crontab -l
– 检查crond服务是否启动:service crond status
– yum install vixie-cron
– yum install crontabs
注意:
1、检查crontab服务状态:service crond status
控制服务的一些提示:service crond
2、检查Apache(阿帕奇)服务状态:service httpd status
控制服务的一些提示:service httpd
(检查服务状态,服务名后面一般都加d,如crond、httpd)
每分钟都打印当前时间到一个文件中
service crond status #查看服务是否启动
service crond start #如没有启动服务,启动服务
crontab -l #查看当前定时任务列表
crontab -e #打开定时任务列表文件,进行编辑
*/1 * * * * date >> /tmp/log.txt #在最后一行插入内容,保存退出(注意*间的空格)
tail -f /tmp/log.txt #监听log.txt文件内容(动态刷新)
date #查看当前时间
crontab的基本组成:
30 21 * * * service httpd restart
45 4 1,10,22 * * service httpd restart
45 4 1-10 * * service httpd restart
*/2 * * * * service httpd restart
1-59/2 * * * * service httpd restart(奇数分钟重启)
0-58/2 * * * * service httpd restart(偶数分钟重启)
* 23-7/1 * * * service httpd restart
0,30 18-23 * * * service httpd restart
0-59/30 18-23 * * * service httpd restart
通过 man crontab
或者 crontab --help
查看
crontab -u 用户名 -l(默认-u为当前登录用户)
crontab -e
crontab -r [username]
root可以指定用户删除其他用户的crontab文件。 其他用户只可以删除自己的crontab文件
/var/spool/cron
/var/log/cron
1、用户的crontab定时任务保存文件:
/var/spool/cron/root
或者:/var/spool/cron/tabs/root
2、全局(系统)配置文件:
– /etc/crontab
– 注意格式
1.利用命令crontab -e 进入的是用户级别的计划任务
2.用 vi /etc/crontab 进入后编辑的是系统级的计划任务
cd /etc
ls cron*
tail -f /var/log/cron(任务执行日志)
crontab -e实际上是在修改目录/var/spool/cron/root下的用户对应的文件
cd /etc/cron.d
vi sysstat
crontab sysstat
crontab 文件名 会把(crontab -e)文件里的内容都覆盖 ,所以要非常小心
crontab -l -u crontester查找某个用户下的定时程序
cron.d可以认为是对系统级配置的补充,crontab -l,crontab -e看不到,编辑不了cron.d里的配置
可以在该文件夹下自己创建
vi crontest
*/1 * * * * echo 'file in cron.d/crontest'
tail -f /var/log/cron
不可引用环境变量
cd ~
ls -a
可以看到有.bash_profile文件
vim .bash_profile
新增一个环境变量
--------------
APPDIR=/ect
export APPDIR
-----------------
更新到环境变量:
source .bash_profile
检验:
echo $APPDIR
可以正常显示,能够被识别
但是在下面这条命令行添加在crontab里不能被识别
*/1 * * * * echo $APPDIR >> /tmp/appdir.log
————————————————————————
在/var/log/cron任务执行日志中可以看到,但是cat打开/tmp/appdir.log内容是空的
第三个和第五个域之间执行的是或操作 即 星期几和每月几号是或关系
例:4月的第一个星期日早晨1时59分运行a.sh
①59 1 1-7 4 0 /root/a.sh
错误的写法
②59 1 1-7 4 * test
date +%w-eq 0 && /root/a.sh
正确的写法
两小时运行一次date命令
错误:
* 0,2,4,6,8,10,12,14,16,18,20,22 * * * date
正确:
0 */2 * * * date
crontab最小时间是1分钟,控制1分钟执行多次
本应该是同时执行,但第二条被推迟了30s执行,效果就是1分钟执行了2次
*/1 * * * * date>>/root/test/half.log
*/1 * * * * sleep 30s;date>>/root/test/half.log
#!/bin/bash
export ORACLE_BASE=/data/oracle
export ORACLE_HOME=/oracle/product/102
export ORACLE_SID=sidname
export ORACLE_TERM=xterm
export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
export LANG=C
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8
#以上代码为Oracle数据库运行账号oracle的系统环境变量设置,必须添加,否则crontab任务计划不能执行。
date=date +%Y_%m_%d #获取系统当前日期时间
days=5 #设置删除5天之前的备份文件
orsid=ip:port/sidname #Oracle数据库服务器IP、端口、SID
orowner=master_ccpx2 #备份此用户下面的数据
bakuser=master_ccpx2 #用此用户来执行备份,必须要有备份操作的权限
bakpass=passwd #执行备注的用户密码
bakdir=/aaa/bbb/oracle_data #备份文件路径,需要提前创建好
bakdata=$orowner"_"$date.dmp #备份数据库名称
baklog=$orowner"_"$date.log #备份执行时候生成的日志文件名称
ordatabak=$orowner"_"$date.tar.gz #最后保存的Oracle数据库备份文件
cd $bakdir #进入备份目录
mkdir -p $orowner #按需要备份的Oracle用户创建目录
cd $orowner #进入目录
exp $bakuser/$bakpass@$orsid grants=y owner=$orowner file=$bakdir/$orowner/$bakdata log=$bakdir/$orowner/$baklog #执行备份
tar -zcvf $ordatabak $bakdata $baklog #压缩备份文件和日志文件
find $bakdir/$orowner -type f -name "*.log" -exec rm {} \; #删除备份文件
find $bakdir/$orowner -type f -name "*.dmp" -exec rm {} \; #删除日志文件
find $bakdir/$orowner -type f -name "*.tar.gz" -mtime +$days -exec rm -rf {} \; #删除5天前的备份