amoeba for mysql 配置_Amoeba for MySQL的读写分离配置

一、Amoeba概述

1、amoeba简介

Amoeba是一个类似MySQL Proxy的分布式数据库中间代理层软件,是由陈思儒开发的一个开源的java项目。其主要功能包括读写分离,垂直分库,水平分库等,经过测试,发现其功能和稳定性都非常的不错,如果需要构架分布式数据库环境,采用Amoeba是一个不错的方案。目前Amoeba一共包括For aladdin,For MySQL和For Oracle三个版本,本文主要关注For MySQL版本的一个读写分离实现。

Amoeba处于在应用和数据库之间,扮演一个中介的角色,将应用传递过来的SQL语句经过分析后,将写的语句交给Master库执行,将读的语句路由到Slave库执行(当然也可以到Master读,这个完全看配置)。Amoeba实现了简单的负载均衡(采用轮询算法)和Failover。如果配置了多个读的库,则任何一个读的库出现宕机,不会导致整个系统故障,Amoeba能自动将读请求路由到其他可用的库上,当然,写还是单点的依赖于Master数据库的,这个需要通过数据库的切换,或者水平分割等技术来提升Master库的可用性。

2、amoeba与mysql-proxy的区别

在MySQL proxy 6.0版本上面如果想要读写分离并且读集群、写集群机器比较多情况下,用mysql proxy 需要相当大的工作量,目前mysql proxy没有现成的 lua脚本。mysql proxy根本没有配置文件, lua脚本就是它的全部,当然lua是相当方便的。那么同样这种东西需要编写大量的脚本才能完成一 个复杂的配置。而Amoeba只需要进行相关的配置就可以满足需求。

cd1b6ea5d260d1d0f9c0daf48038e4e0.png

二、实验环境服务器角色IP地址安装软件功用操作系统

主服务器172.16.8.1mysql可读写centos6.5

从服务器172.16.8.2mysql只可读,与主服务器做读的负载均衡centos6.5

读写分离服务器172.16.8.3amoeba实现读写分离,将写操作发往主服务器,将读操作进行负载均衡!centos6.5

三、amoeba的详细配置

1、主从服务器的配置

在主服务器上安装mysql#yum -y install mysql mysql-server

修改配置文件:# vim /etc/my.cnf

//添加如下:

server-id       = 1

启动mysql,并 创建授权账户#service mysqld start

#mysql

mysql> grant replication slave,replication client on *.* to "gulong"@‘172.16.8.2‘ identified by ‘123‘;

mysql> flush privileges;

从服务器上的也安装mysql#yum -y install mysql mysql-server

修改配置文件:# vim /etc/my.cnf

//添加如下:

server-id       = 2

relay_log = relay_bin

启动mysql,连接主服务器#service mysqld start

#mysql

mysql> change master to master_host=‘172.16.8.1‘,master_user=‘gulong‘,master_password=‘123‘

查看主从状态:mysql> start slave;

mysql> show slave status\G;

122a272a8f2c6bf6dc359a97ff43f9ef.png

到此,主从服务器配置好了!

2、amoeba的配置

首先下载jdk与amoeba安装包:

安装jdk:#chmod +x jdk-6u31-linux-x64-rpm.bin

#./jdk-6u31-linux-x64-rpm.bin

#vim /etc/profile.d/java.sh

//添加如下内容:

export JAVA_HOME=/usr/java/latest

export PATH=$JAVA_HOME/bin:$PATH

#. /etc/profile.d/java.sh

查看java状态:

3cd9b5f3839bfdd25a71802650846623.png

安装amoeba:#mkdir /usr/local/amoeba

#tar xf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba/

#cd /usr/local/amoeba/

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 。

修改ameoba.xml配置文件[[email protected] ~]# cd /usr/local/amoeba/conf/

[[email protected] conf]# vim amoeba.xml

af28891d01b90d71031a6decaac9cd56.png

4fa18bf01f3db7892cddda770e3741db.png

修改dbServers.xml 配置文件[[email protected] conf]# vim dbServers.xml

//修改如下:

amoeba:dbServers SYSTEM "dbserver.dtd">

${defaultManager}

64

128

3306

test

//设置连接后端数据库的账户密码,需要在主mysql上授权

root

admin

500

500

10

600000

600000

true

true

true

//将172.16.8.1添加为master主服务器

172.16.8.1

//172.16.8.2添加为从的slave服务器

172.16.8.2

//将master与slave添加为一个mysql集群,命名为readservers,采用轮询的负载均衡机制

1

//1代表轮询

master,slave

在主mysql服务器上授权远程连接账户:mysql> grant all on *.* to "root"@‘172.16.%.%‘ identified by ‘admin‘;

mysql> flush privileges;

启动amoeba,并测试:[[email protected] bin]# cd /usr/local/amoeba/

[[email protected] bin]# ./amoeba start

[[email protected] ~]# mysql -uroot -pmypass -h172.16.8.3

a65b2c662458497127e490a4aa9cac8b.png

ac6f2b71ec5dd2be7dbf5008918d303b.png

3、测试:

连接amoeba

创建数据库,MySQL [mysql]> create database wb;//创建数据库

MySQL [mysql]> select user,password from mysql.user;//查询数据库

MySQL [mysql]> show databases;

可以通过使用tcpdump在master、slave服务器上抓包,创建一个数据库,并多使用几次查询语句,验证写操作是否被调度至master(172.16.8.1),而读操作会以轮叫的方式调度至master和slave,可以分摊mysql的读请求![[email protected] ~]# tcpdump -i eth0 -nn -XX ip dst host 172.16.8.1 and tcp dst port 3306

[[email protected] ~]# tcpdump -i eth0 -nn -XX ip dst host 172.16.8.2 and tcp dst port 3306

3786b1ba9b6b6398c546d33cda430d78.png

bde0609a252afe3a277cd52a92463080.png

至此,基于amoeba的读写分离已经介绍完毕,不足之处,请多加指点!

原文:http://584014981.blog.51cto.com/8605371/1413912

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值