一、MYSQL主从复制的原理:
MySQL的主从复制和MySQL的读写分离两者有着紧密联系,首先要部署主从复制,只有主从复制完成了,才能在此基础上进行数据的读写分离。
1 >MySOL支持的复制类型
(1)基于语句的复制。在主服务器上执行的SQL语句,在从服务器上执行同样的语句。MySQL默认采用基于语句的复制,效率比较高。
(2)基于行的复制。把改变的内容复制过去.而不是把命令在从服务器上执行一遍。
(3)混合类型的复制。默认采用基于语句的复制,一旦发现基于语句无法精确复制时,就会采用基于行的复制.
二、 MySQL读写分离原理
简单来说.读写分离就是只在主服务器上写,只在从服务器上读。基本的原理是让主数据库处理事务性查询,而从数据库处理select查询。数据库复制被用来把事务性查询导致的变更同步到群集中的从数据库。
目前较为常见的MySQL读写分离分为两种
1)基于程序代码内部实现
在代码中根据select、insert进行路由分类,这类方法也是目前生产环境应用最广泛的。优点是性能较好.因为在程序代码中实现.不需要增加额外的设备作为硬件开支;缺点是需要开发人员来实现.运维人员无从下手。
2)基于中间代理层实现
代理一般位于客户端和服务器之间,代理服务器接到客户端的请求后通过判断后转发到后端数据库.有两个代表性程序。
三、实验操作:
部署配置实验
实验环境
虚拟机 3台 centos7.9
网卡NAT模式 数量 1
组件包mysql-5.6.36.tar.gz cmake-2.8.6.tar.gz
| 设备 | IP | 备注 |
| Centos01 | 192.168.160.51 | Amoeba |
| Centos02 | 192.168.160.52 | Master |
| Centos03 | 192.168.160.53 | Slave |
3.1 MySQL安装:
安装组件包:
yum -y install gcc gcc-c++ ntp vim net-tools ncurses-devel autoconf
上传mysql安装包 mysql-5.6.36.tar.gz cmake-2.8.6.tar.gz 解压cmakne
- tar zxf cmake-2.8.6.tar.gz
- 编译安装cmake
- cd cmake-2.8.6
- ./configure && gmake && gmake install
解压MySQL
tar zxf mysql-5.6.36.tar.gz
编译安装MySQL
- cd mysql-5.6.36
-
- cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DSYSCONFDIR=/etc -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all
-
- make && make install
创建组和用户:
- groupadd mysql
-
- useradd -M -s /sbin/nologin mysql -g mysql
修改MySQL安装目录权限 复制模默认配置文件
- chown -R mysql:mysql /usr/local/mysql
- cp support-files/my-default.cnf /etc/my.cnf
mysql数据库初始化:
./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
添加MySQL到系统服务:
- cp support-files/mysql.server /etc/init.d/mysqld
-
- chmod +x /etc/init.d/mysqld
-
- chkconfig --add mysqld
启动MySQL服务:
Systemctl start mysql
添加MySQL操作指令系统:
- echo "PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile && . /etc/profile
-
- 登入测试 mysql -u root
3.2 MySQL主从复制:
- cat << EOF >> /etc/ntp.conf
- server 127.127.1.0
- fudge 127.127.1.0 stratum 8
- EOF;
-
- systemctl start ntpd
Ntp服务 slave配置
- yum -y install ntpdate
- ntpdate 192.168.160.51
主服务器 master修改配置文件
- sed -i 's/# server_id = .*/server_id = 11/' /etc/my.cnf
- sed -i '/server_id = 11/a\log_bin = master-bin' /etc/my.cnf
- sed -i '/log_bin = master-bin/a\log-slave-updates = true' /etc/my.cnf
-
- systemctl restart mysqld
创建授权用户 myslave 123456
- mysql -u root
-
- grant replication slave on *.* to 'myslave'@'192.168.10.%' identified by '123456';
-
- flush privileges;
查看节点状态:
show master status;

从服务器配置 slave修改配置文件
- sed -i 's/# server_id = .*/server_id = 22/' /etc/my.cnf
- sed -i '/server_id = 22/a\relay-log = relay-log-bin' /etc/my.cnf
- sed -i '/relay-log = relay-log-bin/a\relay-log-index = slave-relay-bin.index' /etc/my.cnf
-
- systemctl restart mysqld
连接主服务器:
- mysql -u root
-
- change master to master_host='192.168.10.52',master_user='myslave',master_password='123456',master_log_file='master-bin.000001',master_log_pos=837;
-
- start slave;
-
- show slave status\G;

3.2 MySQL 读写分离:
部署Java 运行环境上传安装包 jdk-6u14-linux-x64.bin
- chmod +x jdk-6u14-linux-x64.bin
- ./jdk-6u14-linux-x64.bin
- mv jdk1.6.0_14 /usr/local/jdk1.6
添加Java运行环境变量:
- vim /etc/profile
-
- export JAVA_HOME=/usr/local/jdk1.6
- export CLASSPATH=$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
- export PATH=$JAVA_HOME/lib:/$JAVA_HOME/jre/bin:$PATH:$HOME/bin
- export AMOEBA_HOME=/usr/local/amoeba/
-
- java -version
部署amoeba 、上传amoeba软件包、创建amoeba主目录
- mkdir /usr/local/amoeba
-
- tar zxf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba
-
- tar zxf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba