ASP站长网MySQL实时增量备份,采用binlog日志的好处
掌控所有更改操作,必要时可用于恢复数据
数据库主从复制的必要条件
[root@localhost~]# vim /etc/my.cnf
[mysqld]
.. ..
log-bin=mysql-bin //启用二进制日志,并指定前缀
.. ..
[root@dbsvr1 ~]# service mysqld restart
确认binlog日志文件
新启用binlog后,每次启动MySQl服务都会新生成一份日志文件:
[root@localhost~]# ls /var/lib/mysql/mysql-bin.*
/var/lib/mysql/mysql-bin.000001 /var/lib/mysql/mysql-bin.index
清除binlog日志
删除早前指定版本的binlog日志
RURGE MASTER LOGS TO "binlog日志"
删除所有binlog日志,重新新建日志
RESET MASTETR
分析binlog日志
使用mysqlbinlog工具
格式:mysqlbinlog [选项] 日志文件
常用选项
--start-datatime="YYYY-mm-dd HH:MM:SS"
--stop-datatime="YYYY-mm-dd HH:MM:SS"
--start-position=起止位置
--stop-positon=结束位置
[root@localhost ~]# mysqlbinlog /var/lib/mysql/mysql-bin.000002
[root@localhost ~]# mysqlbinlog --start-datetime="2018-10-20 23:30" /var/lib/mysql/mysql-bin.000002
利用binlog恢复数据
基本方法
使用mysqlbinlog提取历史SQL操作
通过管道交给mysql命令重做
案例
重做第一份binlog所记录的更改操作
执行指定Pos节点范围内的sql命令恢复数据
根据上述日志分析,只要恢复从2018-10-12 20:40:50到2018-10-20 23:15:50之间的操作即可。可通过mysqlbinlog指定时间范围输出,结合管道交给msyql命令执行导入重做:
[root@loclahost ~]# mysqlbinlog \
--start-datetime="2018-10-12 20:40:50" \
--stop-datetime="2018-10-20 23:15:50" \
/var/lib/mysql/mysql-bin.000002 | mysql -u root -p
Enter password:
若是全部重做
[root@loclahost ~]# mysqlbinlog /var/lib/mysql/mysql-bin.000002 | mysql -u root -p
Enter password:
mysql备份工具
mysqlhotcopy不足
仅适用于MyISAM引擎的数据库
备份过程中,数据插入和更新操作都会被挂起
mysqldump不足
效率较低,备份和还原速度慢
备份过程中,数据插入和更新操作会被挂起
XtraBackup工具
在线热备份工具
备份过程中不锁表,适合生产环境适用
支持整体备份和增量备份
组件一xtrabackup:C程序,支持InnoDB和XtraDB
组件二innobackupex:以Perl脚本封装xtrabackup,还支持MyISAM
xtrabackup基本选项
基本选项 解释
--backup 执行备份操作
--target-dir 备份到目标文件夹
--datadir 备份的原始文件夹(Mysql库的位置)
--prepare 准备恢复数据
--increamental-basedir 增量备份时,指定参照的完整备份路径
--incremental-dir 准备恢复目录时,指定增量备份的路径
大型站长资讯类网站! https://www.0792zz.cn