如何使用mysqlbinlog备份binlog搭建Binlog Server
这篇文章给大家分享的是有关如何使用mysqlbinlog备份binlog搭建Binlog Server的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
binlog是增量备份必备之一,在有些场景下,实时或定期备份binlog是有必要的。
其实官方mysqlbinlog自带这个功能。
〇 常用的参数:
-R | --read-from-remote-server 表示开启binlog备份,在对应的主节点上请求binlog到本地。
--raw 被复制过来的binlog以二进制的格式存放,如果不加该参数则为text格式。
-r | --result-file 指定目录或文件名:
若指定了--raw参数,-r的值指定binlog的存放目录和文件名前缀;若没有指定--raw参数,-r的值指定文本存放的目录和文件名。
-t 这个选项代表从指定的binlog开始拉取,直到当前主节点上binlog的最后一个。
--stop-never 持续连续从主节点拉取binlog,持续备份到当前最后一个,并继续下去。该参数包含-t
--stop-never-slave-server-id 默认值65535,用于在多个mysqlbinlog进程或者从服务器的情况下,避免ID冲突。
mysqlbinlog开启备份后,直到连接关闭或者被强制kill才会结束。
可通过ps查看到已经开启的备份进程。
用法示例:完整并保持原样的将远程server的binlog拉到本地,并存放在/data/backup_binlog目录中。
注意,-r指定的目录必须写完整,否则会被放在/data目录下,并以"backup_binlog"为前缀命名binlog
如:-r /data/backup_binlog 则会显示为 /data/backup_binlogmysql-bin.000008
mkdir -p /data/backup_binlog
mysqlbinlog -h$ip -P$port -u$user -p$password -R --raw --stop-never mysql-bin.000008 -r /data/backup_binlog/ &
[root@sAno1y backup_binlog]# mysql -h$ip -P$port -u$user -p$password -e "SHOW BINARY LOGS"
mysql: [Warning] Using a password on the command line interface can be insecure.
+------------------+------------+
| Log_name | File_size |
+------------------+------------+
| mysql-bin.000008 | 1073742873 |
| mysql-bin.000009 | 284594590 |
| mysql-bin.000010 | 396303459 |
| mysql-bin.000011 | 154 |
| mysql-bin.000012 | 154 |
| mysql-bin.000013 | 154 |
+------------------+------------+
检查拉取过来的binlog,与show binary logs结果一致。
[root@sAno1y backup_binlog]# ll
total 1713580
-rw-r----- 1 root root 1073742873 Aug 22 17:12 mysql-bin.000008
-rw-r----- 1 root root 284594590 Aug 22 17:13 mysql-bin.000009
-rw-r----- 1 root root 396303459 Aug 22 17:13 mysql-bin.000010
-rw-r----- 1 root root 154 Aug 22 17:13 mysql-bin.000011
-rw-r----- 1 root root 154 Aug 22 17:13 mysql-bin.000012
-rw-r----- 1 root root 154 Aug 22 17:13 mysql-bin.000013
感谢各位的阅读!关于"如何使用mysqlbinlog备份binlog搭建Binlog Server"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!