搜索
查看: 5744|回复: 0

CentOS使用Crontab定时备份MySQL

[复制链接]

714

主题

354

回帖

2669

积分

管理员

本论坛第一帅

积分
2669

热心会员推广达人宣传达人突出贡献优秀版主荣誉管理论坛元老

QQ
发表于 2018-5-24 19:41:11 | 显示全部楼层 |阅读模式 来自 甘肃陇南

在Centos系统环境下使用Crontab定时备份全量备份Mysql数据库。

CentOS的Crontab任务调度配置文件路径在 /etc/crond.*

用户任务调度任务路径在/var/spool/cron

Crontab默认日志路径 /var/log/cron

1、Crond服务基本管理命令
[pre]
service crond start //启动服务  
service crond stop //关闭服务  
service crond restart //重启服务  
service crond reload //重新载入配置  
[/pre]
查看crontab服务状态:service crond status
手动启动crontab服务:service crond start
2、Crond服务是默认随系统自动启动,如未启动则需要手动启动
[pre]
chkconfig crond on  
[/pre]
3、注意任务调度区分root用户与非root用户。

root用户任务调度编辑 /etc/contab 文件,例如:
[pre]
vi /etc/crontab  
[/pre]
#检测crontab是否在test.txt文件中写入数据  
[pre]
*/1 * * * * root echo 111 >> /home/vagrant/test.txt  
[/pre]
非root用户 可以使用crontab命令
[pre]
创建调度文件 crontab -e  
  
查看调度文件 crontab -l  
  
删除调度文件 crontab -r  
[/pre]
如果无法定时执行任务,可查看日志 /var/log/cron出现 ERROR (getpwnam() failed) 的错误,原来是没有在命令中加入root导致的

分     小时    日       月       星期     命令

0-59   0-23   1-31   1-12     0-6     command      

例如:

*/1 * * * * root /sbin/echo `date` >> /home/test.txt

(取值范围,0表示周日一般一行对应一个任务)

记住几个特殊符号的含义: “*”代表取值范围内的数字, “/”代表”每”, “-”代表从某个数字到某个数字, “,”分开几个离散的数字

4、注意

配置完成任务调度后,需要立刻执行的话,重启服务或重新载入配置。不然需要等2分钟后才会自动开始执行。

还需要注意就是环境变量的问题:

1)脚本中涉及文件路径时写全局路径;
2)脚本执行要用到java或其他环境变量时,通过source命令引入环境变量,如:
[pre]
#!/bin/sh
source /etc/profile
export RUN_CONF=/usr/sbin/mysqldump
备份脚本示例:
[python] view plain copy
#!/bin/bash  
#source /etc/profile  
#设置mysql备份目录  
folder=/home/mysqlbackup/  
#数据库服务器,一般为localhost  
host=10.2.48.90  
mysqldump -h10.2.48.90 -uroot --all-databases | gzip > ${folder}`date +%Y%m%d%H%M%S`.gz  
[/pre]

a4b620d1gw1f4k8op0il4j20dw09674t.jpg
有志者,事竟成,破釜沉舟,百二秦关终属楚. 苦心人,天不负, 卧薪尝胆 ,三千越甲可吞吴
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表