文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql全量备份和增量备份方法

2023-10-11 07:12

关注

文章目录

一、mysql全量备份

使用mysqldump 进行全量备份

1、修改 /etc/my.cnf文件添加如下内容

[mysqldump]user=your_backup_user_namepassword=your_backup_passwor

否则会报:Warning: Using a password on the command line interface can be insecure.

2、测试任务脚本

mysqldump -h localhost -uroot -p123456 --flush-logs --databases databaseName > /home/sql/test.sql# databaseName 备份的数据库# /home/sql/test.sql 备份的文件路径及文件

3、添加执行脚本

DB_HOST="localhost" DB_NAME="storage" #你要备份的数据库BIN_DIR="/usr/bin" BCK_DIR="/usr/local/mysql" #备份文件存放的位置 DATE=`date +%F`mysqldump -h localhost   --flush-logs  --databases  $DB_NAME > $BCK_DIR/storage_$DATE.sql

4、天假定时任务

定时备份使用linux的 crontab 定时执行任务脚本

0 0 * * * sh /usr/your/path/mysqlBackup.sh

二、mysql增量备份

mysql增量备份需要结合binlog来执行

1、修改 /etc/my.cnf文件添加如下内容

#开启binlogserver_id=2log_bin=mysql-binbinlog_format=ROW[mysqladmin]user=your_backup_user_namepassword=your_backup_password

2、重启mysql

service mysqld restart

3、 添加执行脚本

BakDir=/home/mysql/data      #增量备份时复制mysql-bin.00000*的目标目录,提前手动创建这个目录BinDir=/var/lib/mysql        #mysql的数据目录LogFile=/home/mysql/bak.logBinFile=/var/lib/mysql/mysql-bin.index     #mysql的index文件路径,放在数据目录下mysqladmin  flush-logs#这个是用于产生新的mysql-bin.00000*文件Counter=`wc -l $BinFile |awk '{print $1}'`NextNum=0#这个for循环用于比对$Counter,$NextNum这两个值来确定文件是不是存在或最新的for file in  `cat $BinFile`do    base=`basename $file` #basename用于截取mysql-bin.00000*文件名,去掉./mysql-bin.000005前面的./    NextNum=`expr $NextNum + 1`    if [ $NextNum -eq $Counter ]    then        echo $base skip!  >> $LogFile    else        dest=$BakDir/$base        if(test -e $dest)#test -e用于检测目标文件是否存在,存在就写exist!到$LogFile去        then            echo  $base exist! >> $LogFile        else            cp $BinDir/$base $BakDir            echo $base copying >> $LogFile         fi     fidoneecho `date +"%Y年%m月%d日 %H:%M:%S"` $Next Bakup succ! >> $LogFile

4、执行恢复

进入到备份的文件路径 即上面配置的 BakDir=/home/mysql/data 执行以下命令mysqlbinlog mysql-bin.000011 | mysql -u root -p

4、测试是否生效

  1. 执行全量备份脚本
  2. 在数据中随便添加一条数据
  3. 执行增量备份脚本
  4. 删除刚刚添加的数据
  5. 查看 binlog备份路径下的文件
  6. 执行最后一个mysql-bin文件
  7. 查看数据是否已恢复

来源地址:https://blog.csdn.net/weixin_38301116/article/details/130848151

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯