您现在的位置是:首页> 网站开发> MySql
Linux 使用crontab定时备份Mysql数据库
- 3926人已阅读
- 时间:2018-10-16 09:11:10
- 分类:MySql
项目中数据库的数据是至关重要的!在实际项目中,遇到有客户机房断电导致数据库数据丢失的问题,又因为备份容灾不及时,导致部分数据恢复不了,而刚好这部分丢失的数据对于客户来说又是至关重要的,那么怎么办呢?盲羊补牢,为时晚矣!所以,对应日常数据库的自动备份千万不能马虎!首先想到的是,使用Linux的自动定时任务命令crontab对数据库进行定时备份!
linux的sh文件编码一定要是utf-8/unix
1、在/home/test创建新脚本文件test_database_backup.sh:
[root@win7 /]# cd home/test [root@win7 test]# touch test_database_backup.sh [root@win7 test]# chmod 770 test_database_backup.sh
2、使用VI工具编写test_database_backup.sh备份数据库脚本内容:
# Name:test_database_backup.sh # This is a ShellScript For Auto DB Backup and Delete old Backup #备份地址 backupdir=/www/test_backup #备份文件后缀时间 time=_` date +%Y_%m_%d_%H_%M_%S ` #需要备份的数据库名称 db_name=test #mysql 用户名 #db_user= #mysql 密码 #db_pass= #mysqldump命令使用绝对路径 /home/server/mysql-5.6.21/bin/mysqldump $db_name | gzip > $backupdir/$db_name$time.sql.gz #删除7天之前的备份文件 find $backupdir -name $db_name"*.sql.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
3、在以上脚本中并没有填写db_user,db_pass,那么mysqldump怎么连接数据库呢?
[root@win7 /]cd /etc [root@win7 etc]vi my.cnf [mysqldump] quick max_allowed_packet = 16M #在这里输入user及password,在执行mysqldump命令就不用输入用户名和密码了 user=root password=123456
4、使用crontab创建定时任务
[root@win7 /]crontab -e #加入 00 02 * * * /usr/bin/sh /home/test/test_database_backup.sh >> /home/test/test_database_backup.log
再用service crond restart重新启动定时任务服务即可!
相关文章
- MySql常用命令语法总结
- PHP获取操作系统函数
- apache的Rewrite详解
- linux修改用户密码命令
- linux查看与修改主机名
- linux修改SSH默认的端口号22
- 解决ssh登录后闲置时间过长而断开连接
- LINUX查看端口使用情况
- linux下查看CPU信息
- CMD常用命令总结
- Linux下的定时执行任务crontab,可以用于PHP定时执行.
- PHP实现定时任务详解
- ThinkPHP5启动事务处理.
- mysql备份还原数据库的常用命令方法
- mysql主键和外键那点事
- UNIX时间戳的格式化PHP和MYSQL两种方法
- linux之fstab文件详解
- vsftpd虚拟用户之mysql实战详解
- systemctl配置apache、mysql实例
- Mysql授权权限及查询权限,删除权限详解