首页 热点资讯 义务教育 高等教育 出国留学 考研考公
您的当前位置:首页正文

使用MySQL的镜像功能进行数据同步

2020-11-09 来源:华佗小知识

数据库版本:5.1.24。 4.x版本的数据库请自己去找相应文档。 英文版文档的原文地址:http://dev.mysql.com/doc/refman/5.1/en/re

数据库版本:5.1.24。

4.x版本的数据库请自己去找相应文档。

英文版文档的原文地址:

1 在主服务器(master)正常运行的情况下,创建一个专门用来同步数据的用户。

CREATE USER ‘用户名’@'从服务器IP’ IDENTIFIED BY ‘密码’;

GRANT REPLICATION SLAVE ON *.* TO ‘用户名’@'从服务器IP’;

这个用户名和密码(明文)以后会自动保存到从服务器上的master.info里面。

2 修改主服务器上面的my.cnf

[mysqld]

log-bin=mysql-bin

server-id=1

这个镜像系统中的每一台mysql主机都需要一个不同的server-id (1~2的32次方-1)

PS:如果使用了innodb, 还需要加上:

innodb_flush_log_at_trx_commit=1

sync_binlog=1

PS again: 主服务配置文件里面一定不能有 skip-networking

PS3: 主服务器防火墙开放3306端口给从服务器。

然后重新启动主服务器的mysqld,,使配置生效。

3 获取主服务器状态信息并复制数据。

3.1 获取主服务器二进制日志的座标

在主服务器上运行一个mysql客户端,

mysql> FLUSH TABLES WITH READ LOCK;

这会flush所有的数据表,并且阻塞所有的写入操作。

对于innodb类型的表,COMMIT 语句也会阻塞。

不要退出这个mysql客户端,否则这个read lock会失效。

在主服务器上重新打开一个mysql客户端,

mysql > SHOW MASTER STATUS;

+—————+———-+————–+——————+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+—————+———-+————–+——————+

| mysql-bin.003 | 73 | test | manual,mysql |

+—————+———-+————–+——————+

File 字段显示的是二进制日志的文件名

Position 显示的是此文件中的偏移量。 抄下来这二个数据。

They represent the replication coordinates at which the slave should begin processing new updates from the master.

linux

显示全文