如何使用Centos的Crontab和shell脚本进行数据库备份
在Centos系统环境下使用Crontab定时备份全量备份Mysql数据库。
CentOS的Crontab任务调度配置文件路径在 /etc/crond.*
用户任务调度任务路径在/var/spool/cron
Crontab默认日志路径 /var/log/cron
1、Crond服务基本管理命令
- servicecrondstart//启动服务
- servicecrondstop//关闭服务
- servicecrondrestart//重启服务
- servicecrondreload//重新载入配置
- 查看crontab服务状态:servicecrondstatus
- 手动启动crontab服务:servicecrondstart
2、Crond服务是默认随系统自动启动,如未启动则需要手动启动
- chkconfigcrondon
3、注意任务调度区分root用户与非root用户。
root用户任务调度编辑 /etc/contab 文件,例如:
- vi/etc/crontab
- #检测crontab是否在test.txt文件中写入数据
- */1****rootecho111> > /home/vagrant/test.txt
非root用户 可以使用crontab命令
- 创建调度文件crontab-e
- 查看调度文件crontab-l
- 删除调度文件crontab-r
如果无法定时执行任务,可查看日志 /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命令引入环境变量,如:
catstart_cbp.sh
#!/bin/sh
source/etc/profile
exportRUN_CONF=/usr/sbin/mysqldump
备份脚本示例:
- #!/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
以上就是关于“如何使用Centos的Crontab和shell脚本进行数据库备份”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注网络,小编每天都会为大家更新不同的知识。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: 如何使用Centos的Crontab和shell脚本进行数据库备份
本文地址: https://pptw.com/jishu/649490.html