Linux系统下MySQL读写分离

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 


目录

一、基于Amoeba读写分离

1.基于程序代码内部实现

2.基于中间代理层实现

三、操作步骤

1.在主机Amoeba上安装java环境

2.安装并配置Amoeba

3.配置Amoeba读写分离,两个Slave读负载均衡

3.1在Master、Slave1、Slave2服务器中配置Amoeba的访问授权

master

slave1

slave2

3.2编辑amoeba.xml配置文件

3.3编辑dbServer.xml配置文件

3.4配置无误后,启动Amoeba软件,默认端口是TCP协议8066\

3.5在Client上进行访问测试

3.6然后可以通过代理访问MySQL

4.主服务器

5.分别在两台从服务器上


一、基于Amoeba读写分离

          在实际的生产环境中,如果对数据库的读和写都在同一个数据库服务器中操作,无论是安全性,高可用还是并发等各个方面都不能完全满足实际需求的,因此一般来说都是通过主从复制的方式来同步数据,再通过读写分离来提供数据的高并发负载能力这样的方案来进行部署。

         简单来说,读写分离就是只在主服务器上写,只在从服务器上读,基本的原理是让主数据库处理事务性查询,而从数据库处理select查询,数据库复制被用来把事务性查询导致的改变更新同步到集群中的从数据库。

Linux系统下MySQL读写分离_第1张图片

二、 目前最常见的MySQL读写分离方案有两种:

1.基于程序代码内部实现

            在代码中根据select,insert进行路由分类,这类方法也是目前大型生产环境应用最广泛的,优点是性能最好,因为在程序代码中实现,不需要增加额外的设备作为硬件开支,缺点是需要开发人员来实现,运维人员无从下手

2.基于中间代理层实现

           代理一般位于客户端和数据库服务器之间,代理服务器接到客户端请求后通过判断转发到后端数据库,代表性程序:

(1)mysql-proxy为mysql开发早期开源项目,通过其自带的lua脚本进行SQL判断,虽然是mysql的官方产品,但是mysql官方不建议将其应用到生产环境。

(2)Amoeba(变形虫)该程序由java语言及逆行开发,阿里巴巴将其应用于生产环境,它不支持事物和存储过程。

           MySQL Master IP:192.168.200.111

           MySQL Slave1 IP:192.168.200.112

           MySQL Slave2 IP:192.168.200.113

           MySQL Amoeba IP:192.168.200.114

           MySQL Client IP:192.168.200.115

Linux系统下MySQL读写分离_第2张图片

           Amoeba(变形虫)项目开源框架于2008年发布一款Amoeba for mysql软件,这个软件致力于mysql的分布式数据库前端代理层,主要为应用层访问mysql的时候充当SQL路由功能,并具有负载均衡,高可用性,SQL过滤,读写分离,可路由到相关的目标数据库,可并发请求多台数据库,通过Amoeba能够完成多数据源的高可用,负载均衡,数据切片的功能,目前Amoeba已经在很多企业的生产线上使用。

三、操作步骤

1.在主机Amoeba上安装java环境

检查java环境—java version

查找Java路径—which Java

若版本不对 rm 删除Java 从新安装java

2.安装并配置Amoeba

3.配置Amoeba读写分离,两个Slave读负载均衡

3.1在Master、Slave1、Slave2服务器中配置Amoeba的访问授权

master

 grant all on *.* to 'test'@'192.168.200.%' identified by '123.com';

flush privileges;

slave1

 grant all on *.* to 'test'@'192.168.200.%' identified by '123.com';

flush privileges;

slave2

grant all on *.* to 'test'@'192.168.200.%' identified by '123.com';

flush privileges;

3.2编辑amoeba.xml配置文件

vim /usr/local/amoeba/conf/amoeba.xml

第一处

Linux系统下MySQL读写分离_第3张图片

第二处

Linux系统下MySQL读写分离_第4张图片

3.3编辑dbServer.xml配置文件

 vim /usr/local/amoeba/conf/dbServers.xml

第一处

Linux系统下MySQL读写分离_第5张图片

 第二处

Linux系统下MySQL读写分离_第6张图片

第三处

 Linux系统下MySQL读写分离_第7张图片

3.4配置无误后,启动Amoeba软件,默认端口是TCP协议8066\

/usr/local/amoeba/bin/amoeba start &

 netstat -lnpt | grep 8066

netstat -anpt | grep 3306

Linux系统下MySQL读写分离_第8张图片

3.5在Client上进行访问测试

# yum -y install mariadb mariadb-devel

 mysql -uamoeba -p123456 -h 192.168.200.114 -P 8066

Linux系统下MySQL读写分离_第9张图片

3.6然后可以通过代理访问MySQL

在MySQL主服务器上创建一个表,会自动同步到各个从服务器上,然后关掉各个服务器上的Slave功能,在分别插入语句测试。

4.主服务器

create database lsq;

use lsq

create table student (id int(10),name varchar(10),address varchar(20));

Linux系统下MySQL读写分离_第10张图片

5.分别在两台从服务器上

 5.1master

use lsq;

 insert into student values('1','Rich','this_is_master');

Linux系统下MySQL读写分离_第11张图片

5.2 slave1

use lsq;

 insert into student values('1','Rich','this_is_slave1');

5.3 slave2

use lsq

 insert into student values('1','Rich','this_is_slave2');

6.操作测试

1.1在客户机上第1次查询结果

Linux系统下MySQL读写分离_第12张图片

1.2在客户机上第2次查询结果

Linux系统下MySQL读写分离_第13张图片  

1.3在客户机上第3次查询结果

Linux系统下MySQL读写分离_第14张图片

2.测试写操作

客户端:insert into student values ('4','Rich','write_test')

查看:select * from student

       但在Client上查询不到,最终只有在Master上才能看到这条语句内容,说明写操作在master服务器上

Linux系统下MySQL读写分离_第15张图片 

由此验证,已经实现了MySQL读写分离,目前所有的写操作都在Master主服务器上,用来避免数据的不同步,所有的读操作都平分给了Slave从服务器,用来分担数据库压力。

分别在两台从服务器上启用slave功能

现在在Client测试机上查看

Linux系统下MySQL读写分离_第16张图片

 

你可能感兴趣的:(mysql,数据库)