mysql5.5主从同步复制配置(二)

2015-01-25 20:29:59 · 作者: · 浏览: 10
过scp命令复制到从库slave上,如下:

scp ilanni.sql root@192.168.1.214:/root

clip_image012

六、配置从库slave同步复制时所需要的选项

从库slave上我们只需要在my.cnf文件中,修改server-id值为唯一即可。如下:

cat /etc/my.cnf|grep -v ^#|grep -v ^$

clip_image013

七、在从库slave上创建数据库ilanni并导入备份

我们在第五步已经把ilanni的备份文件通过scp命令复制到从库,现在我们需要在从库slave上,然后把备份的数据导入进去。如下:

create database ilanni;

mysql –uroot –p123456 ilanni

clip_image014

clip_image015

通过上图,我们可以看到目前从库已经完全恢复ilanni数据库

八、解锁主库master表

从库slave的ilanni数据库创建并导入备份后,我们现在来解锁主库master表,使用如下命令:

unlock tables;

clip_image016

九、设置从库slave与主库master同步

在第七步中我们已经恢复ilanni数据库的数据,我们来开始设置从库slave与主库master同步,使用如下命令:

change master to master_host='192.168.1.213',master_user='ilanni',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=1616, master_connect_retry=100;

其中:master_host表示是主库的IP

master_user表示主库master上允许同步的用户

maser_password表示同步用户的密码

master_log_file表示从哪个binlog文件开始同步

master_log_pos表示从该binlog文件的那个pos节点位置开始同步

master_connect_retry表示从库slave与主库master同步周期,默认是60s。

注意:master_log_file和master_log_pos,就是我们在第四步记录的binlog文件名和pos位置节点。

clip_image017

十、在从库slave上开启同步

以上配置完毕后,我们现在来开启主从同步。开启主从同步,我们需要在从库上开启。开启主从同步非常简单,只需一条命令即可,如下:

start slave;

clip_image018

以上就开启了mysql主从同步复制的开关。我们使用如下命令检查,同步是否正常。如下:

show slave status\G;

clip_image019

我们查看同步是否主要是查看Slave_IO_Running与Slave_SQL_Running选项。如果正常同步,这两选必须同时为YES。

如果Slave_IO_Running为NO,说明可能是从库与主库的网络不通。

如果Slave_SQL_Running为NO,说明很可能是从库与主库的数据不一致。

通过上图,我们可以看到目前Slave_IO_Running和Slave_SQL_Running都为YES。说明现在主从同步是正常的。

并且通过上图,我们也可以看到从库slave与主库master刚开始同步时的binlog文件名以及开始同步时的pos位置节点。

十一、查看从库slave的relay-log以及master.info

现在我们来查看从库relay-log以及master.info信息,我们首先看relay-log信息,如下:

clip_image020

mysqlbinlog ilanni-relay-bin.000002|more

clip_image021

通过这张图,我们可以在relay-log日志中看到,从库slave开始同步主库的binlog文件名以及同步复制时的pos位置节点。

现在我们来查看master.info,如下:

cat master.info |more

clip_image022

可以看到这个文件保存了从库slave同步主库master时的相关信息:IP、用户、密码、binlog文件名、pos位置节点、同步周期。

十二、测试主从同步

现在我们来测试下,mysql的主从同步。先在主库master上给ilanni数据库插入和删除一条数据。如下:

insert into ilannitable values(6);

delete from ilannitable where id=2;

select id from ilannitable;

clip_image023

此时主库master的ilanni数据库中只有1、3、4、5、6,这个5条数据。

现在我们登录从库slave,查看下ilanni数据库的情况。如下:

clip_image024

通过上图,我们可以看到从库slave中的ilanni数据库和主库master中的ilanni数据库,数据是一致。说明主从已经同步复制已经成功。

现在我们再来查看master.info文件的信息,如下:

mysqlbinlog /usr/local/mysql/data/mysql-bin.000003

cat master.info |more

clip_image025

通过上图中,主库的binlog文件的pos位置节点与master.info对比。我们可以发现master.info文件中确实记录了mysql在同步复制时的binlog文件名以及pos位置节点。

至此,有关mysql主从同步复制的实验暂时告一段落。