目录
5、在master上新建一个授权用户,给slave来复制二进制日志
9、测试(在master主机上输入SQL语句操作,看slave是否同步)
一:数据库主从复制原理
MySQL的主从复制方案,和上述文件及文件系统级别同步是类似的,都输数据的传输。只不过MySQL无需借助第三方工具,而是其自带的同步复制功能,另外一点,MySQL的主从复制并不是从硬盘给上文件直接同步,而是逻辑的binlog日志同步到本地的应用执行的过程
数据复制过程的步骤如下 :
1、在Slave 服务器上执行start slave命令开启主从复制开关,开始进行主从复制。
2、此时,Slave服务器的IO线程会通过在master上已经授权的复制用户权限请求连接master服务器,并请求从执行binlog日志文件的指定位置(日志文件名和位置就是在配置主从复制服务时执行change master命令指定的)之后开始发送binlog日志内容。
3、Master服务器接收到来自Slave服务器的IO线程的请求后,其上负责复制的IO线程会根据Slave服务器的IO线程请求的信息分批读取指定binlog日志文件指定位置之后的binlog日志信息,然后返回给Slave端的IO线程。返回的信息中除了binlog日志内容外,还有在Master服务器端记录的IO线程。返回的信息中有binlog中的下一个指定更新位置。
4、当Slave服务器的IO线程获取到Master服务器上dump线程发送的日志内容、日志文件及位置点后,会将binlog日志内容依次写到Slave端自身的Relay Log(即中继日志)文件(Mysql-relay-bin.xxx)的最末端,并将新的binlog文件名和位置记录到master-info文件中,以便下一次读取master端新binlog日志时能告诉Master服务器从新binlog日志的指定文件及位置开始读取新的binlog日志内容。
5、Slave服务器端的SQL线程会实时检测本地Relay Log 中IO线程新增的日志内容,然后及时把Relay LOG 文件中的内容解析成sql语句,并在自身Slave服务器上按解析SQL语句的位置顺序执行应用这样sql语句,并在relay-log.info中记录当前应用中继日志的文件名和位置点。
搭建主从复制集群的目的
增加业务高可用和负载均衡,数据备份
数据库的负载均衡概念:读写分离,写到主服务器,读从数据库。
二:主从复制的条件
1、主需要开启Binlog功能
2、主库要建立账号(授权从服务器过来复制binlog)
3、从库要配置master.info(CHANGE MASTER to…相当于配置密码文件和Master的相关信息)
4、start slave 开启复制功能
三:主从复制的搭建
1、准备服务器&配置环境
master | 192.168.149.160 |
slave | 192.168.149.167 |
1)两台机器都配置静态IP
BOOTPROTO="none"
NAME="ens33"
DEVICE="ens33"
ONBOOT="yes"
IPADDR=192.168.149.160 #两台服务器,这里注意更改
PREFIX=24
GATEWAY=192.168.149.2
DNS1=114.114.114.114
2)修改主机名
hostnamectl set-hostname slave #主机改sc-master
<