当前位置: 首页 > news >正文

如何远程备份MySQL binlog

以前备份binlog时,都是先在本地进行备份压缩,然后发送到远程服务器中。但是这其中还是有一定风险的,因为日志的备份都是周期性的,如果在某个周期中,服务器宕机了,硬盘损坏了,就可能导致这段时间的binlog就丢失了。

而且,以前用脚本对远程服务器进行备份的方式,有个缺点:无法对MySQL服务器当前正在写的二进制日志文件进行备份。所以,只能等到MySQL服务器全部写完才能进行备份。而写完一个binlog的时间并不固定,这就导致备份周期的不确定。

从MySQL5.6开始,mysqlbinlog支持将远程服务器上的binlog实时复制到本地服务器上。

mysqlbinlog的实时二进制复制功能并非简单的将远程服务器的日志复制过来,它是通过MySQL 5.6公布的Replication API实时获取二进制事件。本质上,就相当于MySQL的从服务器。与普通服务器类似,主服务器发生事件后,一般都会在0.5~1秒内进行备份。

备份命令

mysqlbinlog --read-from-remote-server --raw --host=192.168.244.145 --port=3306 --user=repl --password=repl --stop-never mysql-bin.000001

解释如下:

--read-from-remote-server:用于备份远程服务器的binlog。如果不指定该选项,则会查找本地的binlog。

--raw:binlog日志会以二进制格式存储在磁盘中,如果不指定该选项,则会以文本形式保存。

--user:复制的MySQL用户,只需要授予REPLICATION SLAVE权限。

--stop-never:mysqlbinlog可以只从远程服务器获取指定的几个binlog,也可将不断生成的binlog保存到本地。指定此选项,代表只要远程服务器不关闭或者连接未断开,mysqlbinlog就会不断的复制远程服务器上的binlog。

mysql-bin.000001:代表从哪个binlog开始复制。

除了以上选项外,还有以下几个选项需要注意:

--stop-never-slave-server-id:在备份远程服务器的binlog时,mysqlbinlog本质上就相当于一个从服务器,该选项就是用来指定从服务器的server-id的。默认为-1。

--to-last-log:代表mysqlbinlog不仅能够获取指定的binlog,还能获取其后生成的binlog,获取完了,才终止。如果指定了--stop-never选项则会隐式打开--to-last-log选项。

--result-file:用于设置远程服务器的binlog,保存到本地的前缀。譬如对于mysql-bin.000001,如果指定--result-file=/test/backup-,则保存到本地后的文件名为/test/backup-mysql-bin.000001。注意:如果将--result-file设置为目录,则一定要带上目录分隔符“/”。譬如--result-file=/test/,而不是--result-file=/test,不然保存到本地的文件名为/testmysql-bin.000001。

不足:

这个方式有个问题,对于常规的主从复制来说,如果主从直接的连接断开了,则从会自动再次连接,而对于mysqlbinlog,如果断开了,并不会自动连接。

解决方案:

可通过脚本来弥补上述不足。

#!/bin/sh BACKUP_BIN=/usr/bin/mysqlbinlog LOCAL_BACKUP_DIR=/backup/binlog/ BACKUP_LOG=/backup/binlog/backuplog REMOTE_HOST=192.168.244.145 REMOTE_PORT=3306 REMOTE_USER=repl REMOTE_PASS=repl FIRST_BINLOG=mysql-bin.000001 #time to wait before reconnecting after failure SLEEP_SECONDS=10 ##create local_backup_dir if necessary mkdir -p ${LOCAL_BACKUP_DIR} cd ${LOCAL_BACKUP_DIR} ## 运行while循环,连接断开后等待指定时间,重新连接 while : do if [ `ls -A "${LOCAL_BACKUP_DIR}" |wc -l` -eq 0 ];then LAST_FILE=${FIRST_BINLOG} else LAST_FILE=`ls -l ${LOCAL_BACKUP_DIR} | grep -v backuplog |tail -n 1 |awk '{print $9}'` fi ${BACKUP_BIN} --raw --read-from-remote-server --stop-never --host=${REMOTE_HOST} --port=${REMOTE_PORT} --user=${REMOTE_USER} --password=${REMOTE_PASS} ${LAST_FILE} echo "`date +"%Y/%m/%d %H:%M:%S"` mysqlbinlog停止,返回代码:$?" | tee -a ${BACKUP_LOG} echo "${SLEEP_SECONDS}秒后再次连接并继续备份" | tee -a ${BACKUP_LOG} sleep ${SLEEP_SECONDS} done

脚本解读:

1. 实际上定义了一个死循环,如果备份失败,则10s后重新连接。

2. 第一次运行时需指定FIRST_BINLOG的值,指从哪个binlog开始复制,一般为mysql-bin.000001。后续执行的时候就直接获取备份目录下最新的binlog,从最新的binlog开始复制。

总结:

1. 如果指定了--raw,mysqlbinlog获取事件后,并不会实时落盘,而是先保存在本地服务器的内存中,每4K刷盘一次。这也就减少了频繁的日志写操作。如果此时mysqlbinlog和主服务器之间的连接断开了,则内存中的binlog会马上刷新到磁盘中。

2. 尽管mysqlbinlog类似于从服务器,但从服务器上的relaylog却是实时存盘的,即从服务器获取主服务器产生的事件后,会实时写入到relaylog中。

3. 如果不指定--raw,这个时候会以文本格式存盘,此时,--result-file=/test/不能指定为目录,必须明确写上文件名,譬如--result-file=/test/1.sql,此时,mysqlbinlog获取事件后,是实时落盘的,不会每4K刷盘一次。

http://www.zskr.cn/news/1476319.html

相关文章:

  • 保姆级教程:在Linux上一步步搭建HBase伪分布式环境(Hadoop 2.7 + HBase 2.1.1)
  • STM32CubeMX实战:用待机模式+RTC闹钟做个低功耗定时器(附完整代码)
  • ZLUDA终极实战指南:让非NVIDIA显卡运行CUDA应用深度解析
  • 如何快速掌握KDiskMark:Linux磁盘性能测试终极指南
  • 2026年 钢管厂家实力推荐:锥形钢管/热轧无缝化钢管/热浸塑钢管/精拉钢管/精密钢管/320不锈钢管等源头品牌深度解析 - 企业推荐官【官方】
  • 2026 年 6 月北京离婚财产维权:曹子燕律师深挖隐匿婚内资产实操攻略 - 外贸老黄
  • 私域引流被限≠账号违规!CSDN AI数字营销自动注入可信身份标签的4层可信链构建(含平台API级对接日志截图)
  • 别再为作者署名发愁了!LaTeX IEEE/ACM模板多作者排版保姆级教程(含超链接邮箱配置)
  • 2026年工业炉(回火炉/推杆炉/箱式高温炉等)厂家推荐榜:燃气与电热核心技术及热处理设备实力之选 - 企业推荐官【官方】
  • 2026优选:上海格林尼包装有限公司与同业实力供应商深度分析 - 品牌企业推荐师(官方)
  • 佛山黄金回收上门服务哪家好 2026年6月五区正规门店盘点 - 余生黄金回收
  • 像素风兔子跳跃闯关游戏源码:空格起跳、方向键移动、躲飞弹捡火箭道具
  • Windows下Qt Creator 6.0开发环境快速搭建:手把手解决安装后启动与配置问题
  • 如何用SupContrast实现监督对比学习:提升图像分类性能的完整指南
  • 2026德州实地走访测评黄金白银铂金彩金回收诚信门店TOP榜 - 余生黄金回收
  • 2026年 交通杆件生产厂家甄选:八角监控杆/综合杆/电子警察杆/交通F杆实力品牌深度测评 - 品牌企业推荐师(官方)
  • AI 产品商业化路径:从 MVP 到规模化盈利的探索
  • 赤峰黄金上门回收 六家正规门店实测指南 - 余生黄金回收
  • MATLAB信号分析实战:从CSV数据到1/3倍频程图的完整流程(附避坑指南)
  • 2026年 高频焊接机/高频诱导焊接机/全自动高频焊接设备/铜产品焊接设备/制冰机焊接机源头厂家推荐:焊接精度与设备稳定性双优之选 - 企业推荐官【官方】
  • 2026年铝线电缆厂家推荐排行榜:BLVV/YJLV/YJLHV/光伏铝线/铠装铝合金电缆源头品牌深度解析 - 企业推荐官【官方】
  • 深入解析时钟信号相位噪声与抖动:从原理到硬件设计实践
  • 【无人机避障】基于最大体积内接椭圆的迭代膨胀算法实现GPS信号拒止环境下无人机避障附matlab代码
  • DeepL Chrome翻译插件:浏览器内专业级翻译体验完全指南
  • 上海离婚纠纷律师推荐榜(2026年6月):5位专业靠谱律师执业梳理 - 外贸老黄
  • 2026年 常州格力中央空调总代理最新推荐:商用/家用格力空调总代理,专业工程服务与高效售后口碑之选 - 企业推荐官【官方】
  • STM32F4标准库下,用DMA+FSMC驱动TFT-LCD,让你的界面刷新快人一步(附完整代码)
  • OpenCV+Python轻量级指纹活体检测系统
  • 2026年徐州黄金回收市场全维度测评与选购指南 - 寻茫精选
  • 从零部署:在统信UOS服务器版为达梦DM8创建专用dmdba用户与环境