mysqlbinlog 远程备份

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

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

下面主要介绍mysqlbinlog的远程拉取日志命令及主要参数:

命令示例:mysqlbinlog -v --base64-output=DECODE-ROWS --read-from-remote-server --raw --host=x.x.x.x --port=3306 --user=root --password=123456 --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才可以按顺序复制没有出现在命令行的文件(比如mysql-bin.000002,mysql-bin.000003等, 如果只是想拉取指定的几个文件,多个文件之间用空格间隔即可)。
 
-v --base64-output=DECODE-ROWS 命令用于二进制日志文件sql命令base64的解码
 
--database 指定数据库名称
 
除了以上选项外,还有以下几个选项需要注意:
 
--stop-never-slave-server-id:在备份远程服务器的binlog时,mysqlbinlog本质上就相当于一个从服务器,
该选项就是用来指定从服务器的server-id的。默认为-1。
 
--to-last-log:代表mysqlbinlog不仅能够获取指定的binlog,还能获取其后生成的binlog,
获取完了,才终止。如果指定了--stop-never选项则会隐式打开--to-last-log选项。
 
--result-file:用于设置远程服务器的binlog,保存到本地的前缀(如果没有--row,则为文件名)。譬如对于mysql-bin.000001,
如果指定--result-file=/test/backup-,则保存到本地后的文件名为/test/backup-mysql-bin.000001。
注意:如果将--result-file设置为目录,则一定要带上目录分隔符“/”。譬如--result-file=/test/,
而不是--result-file=/test,不然保存到本地的文件名为/testmysql-bin.000001
 
--raw不支持--database,--start-datetime,--end-datetime,--end-position
 
实际案例:
mysqlbinlog -v --base64-output=DECODE-ROWS --read-from-remote-server --raw --host=10.89.181.31--port=3310 --user=root --password=123456 --stop-never mysql-bin.000001

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值