看完你就不用再问我MySQL主从复制如何实现了

Posted PHP自学中心

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了看完你就不用再问我MySQL主从复制如何实现了相关的知识,希望对你有一定的参考价值。

文章来自:https://haveyb.blog.csdn.net/article/details/81086243

点击加入:




精选文章正文

视频教程推荐:【全网最新版本 MySQL8 全套视频教程】
链接:http://www.mano100.cn/thread-526-1-1.html



mysql之间数据复制的基础是二进制日志文件(binary log file)。一台MySQL数据库一旦启用二进制日志后,其作为master,它的数据库中所有操作都会以“事件”的方式记录在二进制日志中,其他数据库作为slave通过一个I/O线程与主服务器保持通信,并监控master的二进制日志文件的变化。


如果发现master二进制日志文件发生变化,则会把变化复制到自己的中继日志中,然后slave的一个SQL线程会把相关的“事件”执行到自己的数据库中,以此实现从数据库和主数据库的一致性,也就实现了主从复制。


一、环境介绍

LNMPcentos7mysql5.6
vmware workstation pro 配置了3个虚拟机,均安装了LNMP环境:
master:  192.168.0.105      
slave:    192.168.0.106 、192.168.0.107


二、原理

1)主数据库进行增删改操作后,相应操作记录的语句(比如 create database test)会记录到binlog日志文件中(binlog日志文件一般和数据库data文件夹在一起)。

2)从数据库会请求主数据库的binlog日志文件,获取到新的操作语句,然后在自己的从数据库上自动执行相同的操作语句,进而实现主从的同步。
 

注:这里,我们所需要配置的只是主从环境以及开启binlog日志,其他的mysql会自动完成。


三、详细主从复制过程

1)Master开启bin-log功能,binlog日志文件用于记录数据库的增删改操作。

2)需要开启三个线程,Master:I/O线程;Slave:I/O线程,SQL线程。

3)Slave start;通过I/O线程连接Master,并且请求某个bin-log,position之后的内容。

4)Master服务器收到Slave I/O线程发过来的日志请求信息,然后Master I/O线程将bin-log内容、position返回给Slave IO线程。

5)Slave服务器收到bin-log日志内容,将bin-log日志内容写入到relay-log中继日志,创建一个master.info文件,该文件记录master IP、用户名、密码、master bin-log名称、bin-log position。

6)Slave已经开启了sql线程,由sql线程实时监测relay-log日志内容是否有更新,如果有更新,则解析文件中的sql语句,并在Slave数据库中执行相同的操作语句。

注:可以通过show slave status G  来查看具体的中继日志路径以及连接的master的其他信息。


四、主从复制的实现

1、master机器上的配置

1)vim /etc/my.cnf   #修改mysql的配置文件

2)配置bind-address (配置成master-ip)和 server-id (改成ip后三位即可,也可以改为其他,比如5)以及开启bin-log(默认是已经开启),如下:

bind-address = 0.0.0.0
server-id = 105



3)创建用于slave机器获取master机器上binlog文件的账号(从机器复制用户)

grant replication slave on *.* to 'xiaobudiu'@'%' identified by 'xiaobudiu123';

4) flush privileges;  #刷新数据库

看完你就不用再问我MySQL主从复制如何实现了

5)show master status; #查看master状态,并记录下binlog日志文件名以及position

看完你就不用再问我MySQL主从复制如何实现了

2、slave机器上的配置

1)在两台从机器上分别配置mysql配置文件中的bind-address 和 server-id

192.168.0.106机器上:

bind-address = 0.0.0.0
server-id = 106


192.168.0.107机器上:

bind-address = 0.0.0.0
server-id = 107


2)分别在两台从库上操作

change master to master_host='192.168.0.105', master_port=3306master_user='xiaobudiu', master_password='xiaobudiu123'master_log_file='mysql-bin.000045', master_log_pos=402;


3)分别开启两台从库

看完你就不用再问我MySQL主从复制如何实现了

4)验证从库状态

当从库的 IO线程和SQL线程的状态都是yes时,说明主从模式配置成功。

主从复制你会了,接下来你应该学习一下MySQL的读写分离,没有为什么。




以上是本文的全部内容,希望对大家的学习有帮助,也希望大家多多支持 php自学中心 ,学习与交流少不了一个圈子,点击加技术群:


以上是关于看完你就不用再问我MySQL主从复制如何实现了的主要内容,如果未能解决你的问题,请参考以下文章

MongoDB是啥,怎么用?看完你就知道了

MongoDB 是啥?看完你就知道了

synchronized如何实现两个线程交替运行?看完你就懂了,列害dei

如何使用Sentinel实现服务熔断和降级,看完你就懂了

MySQL索引-B+树(看完你就明白了)

mysql 7种JOIN理论,看完你就懂了