1.基本概要

两台服务器配置MYSQL主从复制实现数据高可用,这时读与写操作都有由master服务器来完成的,而从服务器只是复制了mster服务器的数据,这时可以利用一台服务器配置Amoeba实现mysql读写分离, master负责写,slave负责读取,当然 也可以有多个salve…… 从而减轻master服务器的压力,实现负载分摊;

 Amoeba for MySQL 读写分离配置_第1张图片

Mysql主从复制原理:

两台mysql服务器一个作为master一个为slave;master上开启二进制日志,将自己所有使数据库发生改变的操作语句记录到而二进制日志中,slave端会开启一个IO线程向master请求masert二进制日志中的事件,master通过binlogdump线程将二进制日志事件发送给slave,slave将接收到的二进制日志时间保存在中继日志(relaylog)中,然后使用sql 线程之行中继日志;从而保证数据与master相同;


Amoeba for MySQL 读写分离配置_第2张图片 


aomeba原理:


aomeba是使用java开发的,所以要首先配置jdk;mysql端配置主从复制,master上的数据复制到slave上,slave主要负责读;aomeba作为一个sql路由调度器,client发来的sql如果是write则分发到write dbserver上,如果是read ,则分发到read dbserver;



2.环境的配置

1java环境的配置

 

Amoeba框架是基于Java SE1.5开发的,建议使用Java SE1.5以上的版本。

 

1.软件包为jdk-7u51-linux-x64.tar,直接解压就可以用了 

2.解压软件包 tarzxf jdk-7u51-linux-x64.tar

3.配置环境java的环境变量 vim /root/.bash_profile 文件

添加配置如下:

 

exportJAVA_HOME=/usr/local/jdk1.7.0_51

exportCLASSPATH=$JAVA_HOME/lib:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

PATH=$JAVA_HOME/bin:$PATH:$HOME/bin 

保存后配置文件生效

 source.bash_profile

 

检查java版本 java  -version

wKiom1TUVlGTnXyoAACjXr43gMo958.jpg


3.安装amoeba软件

# mkdir  /usr/local/amoeba

# unzip  amoeba-mysql-3.0.5-RC-distribution.zip

# /bin/cp –rfamoeba-mysql-3.0.5-RC/* /usr/local/amoeba


4.配置amoeba for mysql

(1.)dbServers.xml   想象Amoeba作为数据库代理层,它一定会和很多数据库保持通信,因此它必须知道由它代理的数据库如何连接,比如最基础的:主机IP、端口、Amoeba使用的用户名和密码等等。这些信息存储在$AMOEBA_HOME/conf/dbServers.xml中。

(2.) rule.xmlAmoeba为了完成数据切分提供了完善的切分规则配置,为了了解如何分片数据、如何将数据库返回的数据整合,它必须知道切分规则。与切分规则相关的信息存储在$AMOEBA_HOME/conf/rule.xml中。

(3.) functionMap.xml当我们书写SQL来操作数据库的时候,常常会用到很多不同的数据库函数,比如:UNIX_TIMESTAMP()SYSDATE()等等。这些函数如何被Amoeba解析呢?$AMOEBA_HOME/conf/functionMap.xml描述了函数名和函数处理的关系。

(4.)ruleFunctionMap.xml$AMOEBA_HOME/conf/rule.xml进行配置时,会用到一些我们自己定义的函数,比如我们需要对用户IDHASH值来切分数据,这些函数在$AMOEBA_HOME/conf/ruleFunctionMap.xml中定义。

(5.)access_list.confAmoeba可以制定一些可访问以及拒绝访问的主机IP地址,这

Amoebafor MySQL 读写分离配置(mysql主从复制配置见前面的博文)

 

部分配置在$AMOEBA_HOME/conf/access_list.conf中。

(6.)log4j.xml  Amoeba允许用户配置输出日志级别以及方式,配置方法使用log4j的文件格式,文件是$AMOEBA_HOME/conf/log4j.xml。其中,我们主要用到dbServer.xml amoeba.xml

Amoeba for MySQL 读写分离配置_第3张图片

Amoeba for MySQL 读写分离配置_第4张图片

配置:


         

${defaultManager}

64

128

192.168.0.154

192.168.0.153

                       

1

server1,server2

5.amoeba.xml 配置:客户端连接Amoeba时所绑定的IP地址、端口、用户名和密码。及IP访问限制。


Amoeba for MySQL 读写分离配置_第5张图片

Amoeba for MySQL 读写分离配置_第6张图片

配置:



3306

128

64

amoeba

123456

${amoeba.home}/conf/access_list.conf

128

500

utf8

60

com.meidusa.toolkit.net.AuthingableConnectionManager

${amoeba.home}/conf/dbServers.xml

${amoeba.home}/conf/rule.xml

${amoeba.home}/conf/ruleFunctionMap.xml

${amoeba.home}/conf/functionMap.xml

1500

multiPool

true

通过以上简单配置,已经可以实现数据库的读写分离了。

 

 

6.测试启动

 

 cd /usr/local/bin/

 ./launcher\\(也可通过nohup后台启动,或者自己写一个脚本来启动。)启动的Amoeba默认端口为3306在客户端连接Amoeba测试:

mysql  -uamoeba –p123456  -h192.168.0.126  --port 3006

mysql> showdatabases;

mysql> CREATEDATABASE zzx; 

\\创建数据库,之后在主从库分别查看通过Amoeba登录,进行数据的查询及插入更新等操作,并查看mysql-log日志,可发现所执行的INSERT UPDATEDELETE等操作在主库server1上操作,SELECT查询语句在从库server2上执行。

 

tcpdump抓包

Tcpdump –i eth0 –nn –X –vv tcp port 3306and ip host 192.168.0.153

Amoeba for MySQL 读写分离配置_第7张图片