Linux下mysql异地自动备份

偏执的太偏执、 2023-02-15 15:52 134阅读 0赞

前言:

基本上不管是对于我们自己使用,还是给客户部署服务器,,mysql备份都是必不可少的一部分,这里给大家分享一下我是如何实现linux上做异地自动备份的。

  • mysql_backup.sh 用于备份数据
  • mysql_restore.sh 用于恢复数据
  • remove_backup.sh 用于删除一段时间以前的备份文件

一、数据备份准备

1.1创建备份目录

  1. 注:这里我是吧备份文件放在/data/backup/mysql下面,把脚本放在 /data/backup 下面

些创建一个文件夹(如果创建过请忽略)

  1. mkdir -p /data/backup/mysql
  2. cd /data/backup

1.2创建脚本文件

创建mysql_backup.sh脚本

  1. vi mysql_backup.sh

粘贴下面的脚本内容

  1. #!/bin/bash
  2. # 需要的话,自己改这里哦
  3. #db_user='root'
  4. #db_password=`cat /data/www/mysql_password`
  5. db_name='wuqilong'
  6. backup_dir='/data/backup/mysql/'
  7. current_time=$(date +'%Y-%m-%d_%H%M%S')
  8. filepath=$backup_dir$current_time'.sql.gz'
  9. #此处没有使用 $db_password $db_user, 已经写入到配置文件中
  10. echo '开始导出数据库...'
  11. mysqldump --defaults-extra-file=/data/backup/my_mysql.cnf $db_name | gzip > $filepath
  12. echo '导出成功,文件名为: '$filepath

新建配置文件, 就在我们的当前目录下 即 /data/backup

  1. vi my_mysql.cnf

下面的是文件内容,这里可以设置一下允许导出的文件大小上限

  • 这里的host填写你需要从那台服务器下进行备份
  1. [mysqldump]
  2. max_allowed_packet = 400M
  3. host=ip地址(192.168.1.**)
  4. user=root
  5. password='root'
  6. [mysql]
  7. host=ip地址(192.168.1.**)
  8. user=root
  9. password='root'

这样导出shell脚本就已经写好了哈,接下来给它加一下权限。

  1. chmod +x ./mysql_backup.sh

现在可以使用下面的命令来导出了

  1. sh ./mysql_backup.sh
  2. # 查看一下结果
  3. ll ./mysql

format_png

发表评论

表情:
评论列表 (有 0 条评论,134人围观)

还没有评论,来说两句吧...

相关阅读