经常备份数据库是一个好习惯, 虽然数据库损坏或数据丢失的概率很低, 但一旦发生这种事情, 后悔是没用的. 一般网站或应用的后台都有备份数据库的功能按钮, 但需要去手工执行. 我们需要一种安全的, 每天自动备份的方法. 下面的这个 shell 脚本就是能让你通过过设定 Crontab 来每天备份 MySQL 数据库的方法.
- #!/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
来源: http://www.webhek.com/post/backing-up-mysql-databases.html