每天自动备份MySQL数据库的shell脚本
2017-02-16 11:13
477 查看
经常备份数据库是一个好习惯,虽然数据库损坏或数据丢失的概率很低,但一旦发生这种事情,后悔是没用的。一般网站或应用的后台都有备份数据库的功能按钮,但需要去手工执行。我们需要一种安全的,每天自动备份的方法。下面的这个shell脚本就是能让你通过过设定Crontab来每天备份MySQL数据库的方法。
通过上面的脚本,我们可以每天导出一份sql备份文件,文件的名称按当日日期生成。日积月累,这样的文件会生成很多,有必要定时删除一些老旧的备份的文件,下面的这行命令就是做这个任务的,你可以把它加在上面的脚本后面。
我在使用上面的脚本时曾经遇到过一个问题,Crontab定时执行脚本导出没有报错,但导出的是空的SQL文件,但登录到控制台手工执行这个脚本是备份成功的。后来发现是Crontab执行脚本是缺少系统环境信息,找不到
stderr。在命令的后面末尾接 “2>&1” 这样一个信息重定向命令就可以看到错误信息了:
#!/bin/bash # 数据库认证 user="" password="" host="" db_name="" # 其它 backup_path="/path/to/your/home/_backup/mysql" date=$(date +"%d-%b-%Y") # 设置导出文件的缺省权限 umask 177 # Dump数据库到SQL文件 mysqldump --user=$user --password=$password --host=$host $db_name > $backup_path/$db_name-$date.sql
通过上面的脚本,我们可以每天导出一份sql备份文件,文件的名称按当日日期生成。日积月累,这样的文件会生成很多,有必要定时删除一些老旧的备份的文件,下面的这行命令就是做这个任务的,你可以把它加在上面的脚本后面。
# 删除30天之前的就备份文件 find $backup_path/* -mtime +30 -exec rm {} \;
我在使用上面的脚本时曾经遇到过一个问题,Crontab定时执行脚本导出没有报错,但导出的是空的SQL文件,但登录到控制台手工执行这个脚本是备份成功的。后来发现是Crontab执行脚本是缺少系统环境信息,找不到
mysqldump,改正的方法是使用
mysqldump全路径就行了。而之所以没有报错信息,是因为
mysqldump把错误信息输出到了
stderr。在命令的后面末尾接 “2>&1” 这样一个信息重定向命令就可以看到错误信息了:
mysqldump -ujoe -ppassword > /tmp/somefile 2>&1
相关文章推荐
- shell脚本每天自动备份mysql数据库
- shell脚本每天自动备份mysql数据库
- shell脚本每天自动备份mysql数据库
- 每天自动备份MySQL数据库的shell脚本
- shell脚本自动备份MySQL数据库
- CentOS Linux自动备份MySQL数据库到远程FTP服务器并删除指定日期前的备份Shell脚本(二)
- MySQL数据库的shell脚本自动备份
- windows下mysql数据库每天自动备份php脚本
- centos每天自动备份mysql数据库方法及脚本
- Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本
- linux服务器实现每天定时备份mysql数据库的shell脚本
- CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中
- CentOS Linux自动备份MySQL数据库到远程FTP服务器并删除指定日期前的备份Shell脚本(一)
- Debian下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本
- CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中
- Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本
- [Mysql数据库] 每天自动备份mysql脚本
- [Mysql数据库] 每天自动备份mysql脚本
- CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中(转)
- Linux 自动备份MySQL数据库shell脚本