mysql数据库主从复制

第一步、配置master

1、 修改master的配置文件,使用二进制日志,指定server-id,重启服务。目的是让各自都有了自己的唯一标示,并以二进制文件格式进行交流。Centos中路径为 /etc/my.cnf。

[mysqld]
log_bin = mysql-bin       [必须]启用二进制日志
server-id=51            [必须]服务器唯一ID,默认是1,一般取IP最后一段

2、配置完成后需要重启mysqlserver才能生效。

systemctl  restart mysqld

3、创建授权用户

登陆主服务器mysql命令行,创建一个用于从服务器复制的用户。

mysql>GRANT REPLICATION SLAVE ON *.* to 'root'@'%' identified by '123456'; 

"*.*"表示对所有库的所有操作,“%”表示所有客户端都可能连,也可用具体客户端IP代替,如172.16.1.51,加强安全。

4、 记录master 状态信息

查看二进制日志文件名,及最新位置。让slave知道用哪个用户信息访问master,知道读取哪个日志文件,及从哪儿开始读。

mysql>show master status;

image
其中file、position字段需要记录下值,mysql-bin.000001 是用于主从复制的文件名,
437是日志文件内的最新位置。

第二步、 配置slave

1、 修改配置文件my.cnf,使用二进制日志,指定server-id,重新启动服务。

[mysqld]
log_bin = mysql-bin 
server-id=52

systemctl restart mysqld

2、 将slave指向master

登陆从服务器mysql命令行,使用之前创建的用户和master的日志文件及其位置。slave中使用被授权用户信息及日志文件信息,进行指向master。这时已经建立了和master的联系,明确了从哪儿读取日志文件。

mysql>change master to master_host='172.16.1.51',master_user='root',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=437;

3、启动slave

mysql>start slave;

4、 查看slave状态

mysql> show slave status\G;

结果中有两个重要数据项:

1.  Slave_IO_Running: Yes IO线程状态,必须YES
2.  Slave_SQL_Running: Yes SQL线程状态,必须YES
常见的问题是SQL线程没有正常工作 Slave_SQL_Running: No。通常是两边的数据库不是完全对应的,需要确保master上的库及到目前为止的最新记录都复制到slave上了。

验证测试

当IO线程和SQL线程都正常后,到master中随意测试下插入、修改、删除操作,同时到slave中检查。

image.png

你可能感兴趣的:(mysql数据库主从复制)