MySQL数据同步-复制

jopen 8年前

一,复制的基本步骤

建立一个简单的复制只需要三个步骤

  1. 配置一个服务器作为主库,就是Master库。
  2. 配置另一个服务器作为从库,就是slave库。
  3. 将从库连接到主库。
二,配置主库

将服务器配置为主库,必要条件是该服务器有一个活动的二进制日志和唯一的服务器ID,这个二进制日志上保存了所有在主库上的数据改变,而服务器ID用于区分标识服务器。要创建二进制日志和服务器ID,需要先将服务器停止,然后配置my.cnf配置文件。
在主库的操作主要包括两上部分,配置二进制日志文件以及添加用于复制的账户;

2.1  配置二进制日志文件

我在我主库的配置文件里添加下面三行:
log-bin         =master-bin  log-bin-index           =master-bin.index  server-id       =1
在我添加这三行之后,重新启动服务,发现在数据目录下多出了两个文件: master-bin.000001,master-bin.index。这两个文件在主从同步中,起到很大的作用。

2.2 添加复制账户

创建账户 : create user repl_user;
给账户复制权限:grant replication slave on *.* to repl_user identified by 'pwd';

三,配置从库

配置完主库之后,还需要配置从库。和主库一样,需要为每个从库分配一个唯一的服务器ID,并添加中继日志文件和中继日志索引文件。如果不添加文件名,会根据hostname有一个默认的文件。

我在从库所在的配置文件里添加:
server-id       =2  relay-log-index =slave-relay-bin.index  relay-log       =slave-relay-bin


四,连接主库和从库

这一步的主要目的是将从库指向主库,让从库知道数据应该从哪个地方复制过来。我们需要了解关于主库的几个基本的信息:
  1. 主机名
  2. 端口号
  3. 主库上拥有REPLICATION SLAVE权限的用户账户。
  4. 该用户的受权密码。
使用 CHANGE MASTER TO 命令将从库指向主库,然后使用 START SLAVE 命令启动复制。
</div>

CHANGE MASTER TO MASTER_HOST='192.168.1.105', MASTER_PORT=3306 ,MASTER_USER='repl_user' ,MASTER_PASSWORD='pwd';

这个命令执行完之后,就可以启动从库了。
在启动完从库之后,用 SHOW SLAVE STATUS命令查看从库是否正常工作。主要是IO和MYSQL线程状态是否正常。

在这以后,在主库上的任何改动,从库也会随之而改动。


按照上面的操作,经测试,数据库可以正常复制

转自:http://blog.csdn.net/zmxiangde_88/article/details/8007873