自学内容网 自学内容网

特定数据库的备份脚本

该脚本 mysql_backup.sh 是一个 MySQL 数据库的备份脚本,以下是它的工作原理和需要注意的细节: 

脚本内容分析

1.设置时间变量 TIME :

TIME=`date +%F_%H-%M-%S`

该变量 TIME 存储当前日期和时间,格式为 YYYY-MM-DD_HH-MM-SS,用于生成备份文件的时间戳。

2. 定义备份目录 DIR :

DIR=/backup

 所有备份文件将存储在 /backup 目录下。

3.  定义数据库名 DB 和密码 PASS

DB=hellodb
PASS=magedu

DB 为要备份的数据库名称PASS 为数据库的密码

 4. 创建备份目录:

[ -d $DIR ] || mkdir $DIR

检查 /backup 目录是否存在,如果不存在则创建该目录。 

5. 执行 mysqldump 命令

mysqldump -uroot -p "$PASS" -F -E -R --triggers --single-transaction --master-data=2 --default-character-set=utf8 -q -B $DB | gzip >
${DIR}/${DB}_${TIME}.sql.gz
  • -u root:使用 root 用户执行备份。
  • -p "$PASS":数据库的密码。
  • -F:刷新日志,生成一个新的二进制日志文件(用于增量备份)。
  • -E:导出数据库的事件。
  • -R:导出存储过程和函数。
  • --triggers:导出触发器。
  • --single-transaction:在一个事务中执行备份(适合 InnoDB 表)。
  • --master-data=2:记录当前二进制日志位置,用于主从复制配置。
  • --default-character-set=utf8:设置字符集为 UTF-8。
  • -q:逐行导出数据,减少内存使用。
  • -B $DB:指定要备份的数据库。
  • gzip:将导出的 SQL 文件压缩。
  • > ${DIR}/${DB}_${TIME}.sql.gz:将输出保存为带时间戳的 .sql.gz 文件。

注意事项

  1. 脚本中的密码安全问题:在生产环境中,不建议将数据库密码直接写在脚本里。可以使用 .my.cnf 文件配置 MySQL 登录凭据。
  2. 备份目录的权限:确保 /backup 目录具有适当的权限,以便用户可以写入。
  3. 数据库用户权限:运行备份的 MySQL 用户需要有足够的权限(如 SELECT, SHOW VIEW, TRIGGER)。
  4. 备份文件的清理:此脚本没有删除旧的备份文件,建议添加清理机制以避免存储空间耗尽。

此脚本可以通过 crontab 设置定时任务,实现自动化数据库备份。


原文地址:https://blog.csdn.net/cj13106811623/article/details/143609655

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!