A-A+

MySQL 读写分离神器Amoeba

2014年02月24日 MySQL 暂无评论 阅读 872 次

一、 安装和运行Amoeba
1. Amoeba for MySQL 架构:
Amoeba

  • Amoeda 配置信息:10.0.0.161
    Master配置信息:10.0.0.162
    Slave配置信息:10.0.0.171
    主服务器(Master)只写不读,从(Slave)只读不写

2. 安装JAVA环境及验证
Amoeba框架是基于Java SE1.5开发的,建议使用Java SE1.5以上的版本。

3. 安装MySQL数据库及配置主从复制部分此处不再阐述,不会者可参考:http://www.minunix.com/2013/05/mysql-slave/ 。
4. 下载Amoeba
本例使用版本:amoeba-mysql-3.0.5-RC-distribution.zip
下载地址:http://pan.baidu.com/s/1fkno
5. 安装Amoeba
把下载的压缩包解压完了之后放到 /usr/local/ 目录下即可。
# mkdir /usr/local/amoeba
# unzip amoeba-mysql-3.0.5-RC-distribution.zip
# /bin/cp –rf amoeba-mysql-3.0.5-RC/* /usr/local/amoeba

二、 配置Amoeba for MySQL:
Amoeba for MySQL的使用是很简单的,主要是通过xml文件来实现的。
1. 配置文件介绍:
(1.) dbServers.xml 想象Amoeba作为数据库代理层,它一定会和很多数据库保持通信,因此它必须知道由它代理的数据库如何连接,比如最基础的:主机IP、端口、Amoeba使用的用户名和密码等等。这些信息存储在$AMOEBA_HOME/conf/dbServers.xml中。
(2.) rule.xml Amoeba为了完成数据切分提供了完善的切分规则配置,为了了解如何分片数据、如何将数据库返回的数据整合,它必须知道切分规则。与切分规则相关的信息存储在$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进行配置时,会用到一些我们自己定义的函数,比如我们需要对用户ID求HASH值来切分数据,这些函数在$AMOEBA_HOME/conf/ruleFunctionMap.xml中定义。
(5.) access_list.conf Amoeba可以制定一些可访问以及拒绝访问的主机IP地址,这部分配置在$AMOEBA_HOME/conf/access_list.conf中。
(6.) log4j.xml Amoeba允许用户配置输出日志级别以及方式,配置方法使用log4j的文件格式,文件是$AMOEBA_HOME/conf/log4j.xml。
其中,我们主要用到dbServer.xml 和 amoeba.xml 。
2. dbServer.xml 的配置:
${defaultManager} 64 128<!—mysql port --><!—代理连接数据库使用的端口号-->
3306 <!—mysql schema --><!—代理连接数据库所使用的数据库-->
test

<!—mysql user --><!—代理连接数据库使用的用户名-->
username <!—代理连接数据库使用的密码-->
password

5005001600000600000truetruetrue


 

10.0.0.162

 

 

 

 

<!—mysql ip -->

10.0.0.171

 

 

 

 

<!—Load balancing strategy: 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA-->

1

<!—Separated by commas,such as: server1,server2,server1 -->

server1,server2

 

 

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

8066

 

 

128

64

 

 

 

 

root

minunix

 

 

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

 

 

 

 

 

以下内容是定义读写分离:
${amoeba.home}/conf/rule.xml

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

 

 

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

1500

multiPool

server1

server2

true

 

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

三、 测试
# cd /usr/local/bin/
# ./launcher \ (也可通过nohup后台启动,或者自己写一个脚本来启动。 )
启动的Amoeba默认端口为8066
在客户端连接Amoeba测试:
# mysql -uroot –p密码 -h10.0.0.161 --port 8066
mysql> show databases;
mysql> CREATE DATABASE Test_amodeba; \ 创建数据库,之后在主从库分别查看
通过Amoeba登录,进行数据的查询及插入更新等操作,并查看mysql-log日志,可发现所执行的INSERT 、UPDATE、DELETE等操作在主库server1上操作,SELECT查询语句在从库server2上执行。

蜗牛的梦想
Copyright © Linux系统运维联盟 保留所有权利.   Theme  Ality 京公网安备11011402000199号 京ICP备14047887号

用户登录