1、原理
MySQL 主从复制就是将一个 MySQL 实例(Master)中的数据实时复制到另一个 MySQL 实
例(slave)中,而且这个复制是一个异步复制的过程。
实现整个复制操作主要由三个进程完成的,其中两个进程在 Slave(sql_thread 和
IO_thread),另外一个进程在 Master(IO 进程)上。
2.主从复制过程
1.Master将用户对数据库更新的操作以二进制格式保存到 Binary Log日志文件中
2.Slave上面的IO进程连接上Master,并请求从指定日志文件的指定位置(或者从最开始的日志)之后的日志内容;
3.Master接收到来自Slave的1o进程的请求后,通过负责复制的I0进程根据请求信息读取制定日志指定位置之后的日志信息,返回给 Slave 的IO进程。返回信息中除了日志所包含的信息之外,还包括本次返回的信息已经到Master端的bin-log文件的名称以及bin-log的位置;
4.Slave的IO进程接收到信息后,将接收到的日志内容依次添加到Slave端的
relay-log文件的最末端,并将读取到的Master端的bin-log的文件名和位置记录到master-info文件中,以便在下一次读取的时候能够清楚的告诉Master“我需要从某个bin-log的哪个位置开始往后的日志内容,请发给我”;
5.Slave的Sql进程检测到relay-log中新增加了内容后,会马上解析relay-log的内容成为在Master端真实执行时候的那些可执行的内容,并在自身执行。
3.MySQL主从复制类型
基于语句的复制(默认)
在主服务器上执行的语句,从服务器执行同样的语句
基于行的复制
把改变的内容复制到从服务器
混合类型的复制
一旦发现基于语句无法精确复制时,就会采用基于行的复制
4.主从复制实操
1.环境
三台centos7服务器 同一安装mysql5.7版本的
一台做master
两台做slave
主 :192.168.174.52 server-id 1
从 :192.168.174.53 server-id 2
从 :192.168.174.54 server-id 3
2.配置时间同步ntp
Master服务器配置
vi /etc/ntp.conf
restrict 192.168.174.0 mask 255.255.255.0 nomodify notrap
server 127.127.1.0 //设置回环地址
fudge 127.127.1.0 stratum 8 //设置时间服务器的层级为8级
配置master主服务器的mysql
vi /etc/my.cnf //在[mysqld]下面配置
server-id = 1
log_bin=master_bin //设置日志开启
log_slave_updates=true //开启日志更新
进入数据库
//为所有从服务器授权所以数据库
mysql >grant replication slave on *.* to ‘myslave’@192.168.174.%’ identified by ‘zhf1021.’;// 给从服务器授权,允许20.0.0.网段的服务器使用myslave访问所有库的所有表
mysql> show grants for 'myslave'@'192.168.174.%';//查询授权
mysql>show master status; //查看主服务器状态,日志用于从服务器同步,position是当前定位
配置MySQL从服务器1
vi /etc/my.cnf //在[mysqld]下面配置
server-id = 1
relay_log=relay_log_bin //从主服务器上同步日志文件记录到本地
relay_log_index=slave-relay-bin.index //建立索引文件,定义relay-log的位置和名称
配置MySQL从服务器2
vi /etc/my.cnf //在[mysqld]下面配置
server-id = 2
relay_log=relay_log_bin //从主服务器上同步日志文件记录到本地
relay_log_index=slave-relay-bin.index //建立索引文件,定义relay-log的位置和名称
mysql>change master to master_host='192.168.174.52' ,master_user='myslav
e',master_password='zhf1021',master_log_file='master_bin.000005',master_log_pos=306;//从主服务器上获取文件进行复制
mysql> show slave status\G;//查看进程是否开启
半同步复制
mysql semi-sync(半同步复制)
半同步复制:
确保事务提交后binlog至少传输到一个从库
不保证从库应用完这个事务的binlog
性能有一定的降低,响应时间会更长
网络异常或从库宕机,卡主主库,直到超时或从库恢复
并行复制
mysql并行复制
并行是指从库多线程apply binlog
库级别并行应用binlog,同一个库数据更改还是串行的(5.7版并行复制基于事务组)
原理
只在主服务器上写,只在从服务器上读
主数据库处理事务性查询,从数据库处理SELECT查询数据库复制用于将事务性查询的变更同步到集群中的从数据库
工作过程
读写分离案例
环境:
一台centos7服务器当做client
一台centos7服务器作为Amoeba服务器
三台centos7服务器作为mysql数据库服务器,一主二从 (主从复制在上面已经搭建好了 直接拿来使用)
主服务器
mysql> grant all privileges on *.* to test@'192.168.174.%' identified by '123.com';//允许所以从服务器登录
安装JDK
--安装JDK-——---
tar xf jdk-8u144-linux-x64.tar. gzcp -rv jdk1.8.0_144/ /usr/local/ javavi /etc/profile
export JAVA_HOME=/usr/local/ javaexport JRE_HOME=/usr/ local/ java/ jreexport PATH=$PATH:/usr/ local/ java/bin
export CLASSPATH=./ : /usr/local/java/lib:/usr/local/java/jre/lib
source /etc/profile
安装amoeba
#JVM_OPTIONS=" -server -Xms256m -Xmx1024m -Xss196k -XX: PermSize=16m-XX:MaxPermSize=96m"
33 JvM_OPTIONS=" -server -Xms1024m -Xmx1024m -XsS256k"
cd /usr/local/amoeba/bin/
launcher
修改amoeba配置文件
28 amoeba
29
30 123456
31
32
33
34 ${amoeba.home}/conf/access_list.conf
76
77 ${amoeba.home}/conf/rule.xml
78 ${amoeba.home}/conf/ruleFunctionMap.xml
79
80
81 ${amoeba.home}/conf/functionMap.xml
82 1500
83 master
84
85
86 master
87 slaves
88
89 true
90
vi /usr/local/amoeba/conf/dbServers.xml
28 amoeba
29
30 123456
31
master
84
85
86 master
87 slaves
88
89 true
测试
在master新建库和表
在两台从服务器上看是否有库及表生成
MySQL [test]> insert into abc values(5,‘cc’,90); #客户机
2 mysql> select * from abc; #主
3 mysql> select * from abc; #从1
4 mysql> select * from abc; #从2