定时任务顾名思义就是在某一时间点自动进行任务操做。
在作Pgsql的备份利用crontab进行定时操做, 使用起来比较方便。故分享
具体的定时编辑命令:crontab -e
首先从crontab的文件分析使用策略,root用户下,在/etc下有一个文件crontab,其内容以下
[root@jack ~]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/
# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
该 文件下的前四行内容为crontab的环境变量,SHELL变量的值指定系统使用的SHELL环境(该样例为bash shell),PATH变量定义了执行命令的路径。Cron的输出以电子邮件的形式发给MAILTO变量定义的用户名。若是MAILTO变量定义为空字符 串(MAILTO=""),电子邮件不会被发送。执行命令或脚本时HOME变量可用来设置基目录。
注:以上系统会默承认以不用修改任何!
在root用户下,能够直接vim /etc/crontab文件进行脚本的添加定时任务脚本,而在其余普通用户下能够经过crontab –e 进行脚本的添加
编辑完成,能够用crontab –l进行查看脚本信息
定时命令脚本解析:
从表格中能够看出脚本格式以下:
minute hour day month week user-name command
minute---分钟 (0-59)
hour------小时(0-23)
day--------日期(1-31)
month---月份(1-12)
week----星期(0-6) //0表明星期天
除了数字还有几个个特殊的符号就是"*"、"/"和"-"、",",*表明全部的取值范围内的数字,"/"表明每的意思,"*/5"表示每5个单位,"-"表明从某个数字到某个数字,","分开几个离散的数字。如下举几个例子说明问题:
以具体例子进行分析定时脚本:
pgslq.sh为须要执行的脚本,内容为须要进行的备份操做或者其余任务脚本
1 * * * * /home/postgres/pgsql.sh
表示的是每小时的第一分钟执行该脚本
2 3 * * * /home/postgres/pgsql.sh
表示天天的3点零2分执行该脚本
1 1 * * 0 / home/postgres/pgsql.sh
表示的是每周的1点1分进行脚本的执行
1 1 1 * * / home/postgres/pgsql.sh
表示的是每个月的1点1分进行脚本的执行
比较容易犯的错误是一般会把每小时的第一分钟按作每分钟执行一次,这点要注意二者的区别:
1 * * * * /home/postgres/pgsql.sh
表示的是每小时的第一分钟执行该脚本
*/1 * * * * /home/postgres/pgsql.sh
表示的是每一分钟执行该脚本
所以这里要记住”/”这个符号带来的区别
“-”的用法:
0 10 * * 1-3 / home/postgres/pgsql.sh
表示的是每一个周一到周三的早上10点执行该脚本
0 10 * * 一、三、5 / home/postgres/pgsql.sh
表示的是每周的周1、周3、周五的早上10点执行该脚本
这些大体就是定时任务的几乎常见的可能性定时脚本。
在表格中看到user-name这个表示的用户该脚本所在的用户,通常状况下在作项目不可能会有root用户进行编写,因此咱们可能直接在普通用户下进行定时脚本的编写,直接执行crontab –e,编写定时任务。
每 次编辑完某个用户的cron设置后,cron自动在/var/spool/cron下生成一个与此用户同名的文件,此用户的cron信息都记录在这个文件 中,这个文件是不能够直接编辑的,只能够用crontab -e 来编辑。cron启动后每过一分钟读一次
sql
---------------------shell
本文来自 不会飞的大象 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/martingpf/article/details/82593336?utm_source=copy vim