http://www.cnblogs.com/xiaocen/p/3736095.html

amoeba实现mysql读写分离

application  shang  2年前 (2013-03-28)  4095浏览  0评论

说明:
要实现mysql的主从读写分离,目前主要有以下几种方案:
1.通过程序实现,网上很多现成的代码,比较复杂,如果添加从服务器要更改多台服务器的代码。
2.通过mysql-proxy来实现,由于mysql-proxy的主从读写分离是通过lua脚本来实现,目前lua的脚本的开发跟不上节奏,而写没有完美的现成的脚本,因此导致用于生产环境的话风险比较大,据网上很多人说mysql-proxy的性能不高。
3.自己开发接口实现,这种方案门槛高,开发成本高,不是一般的小公司能承担得起。
4.利用阿里巴巴的开源项目Amoeba来实现,具有负载均衡、高可用性、sql过滤、读写分离、可路由相关的query到目标数据库,并且安装配置非常简单,但是目前还不支持事务。

本文主要讲如何通过amoeba实现mysql读写分离。

实现:
1.java环境的安装,Amoeba框架是基于Java SE1.5开发的,建议使用Java SE 1.5版本。目前Amoeba经验证在JavaTM SE 1.5和Java SE 1.6能正常运行
可以到http://www.oracle.com/technetwork/java/javasebusiness/downloads/java-archive-downloads-javase6-419409.html#jdk-6u41-oth-JPR免费注册,下载
我这里下载jdk-6u41-linux-x64-rpm.bin,下载完成后执行sh jdk-6u41-linux-x64-rpm.bin开始安装,将会安装到/usr/java/jdk1.6.0_41目录。

2.amoeba编译安装

  1. # cd /usr/local/src/tmp
  2. # mkdir /usr/local/amoeba
  3. # wget http://sourceforge.net/projects/amoeba/files/Amoeba%20for%20mysql/2.2.x/amoeba-mysql-binary-2.2.0.tar.gz/download
  4. # tar xzf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba

3.配置java的用户环境变量

  1. # vi ~/.bash_profile 修改为以下内容:
  2. PATH=$PATH:$HOME/bin:/usr/local/amoeba/bin
  3. JAVA_HOME=/usr/java/jdk1.6.0_41
  4. export JAVA_HOME
  5. export PATH
  6. # source ~/.bash_profile //立即生效

4.1 /usr/local/amoeba/conf/dbServers.xml配置,此文件定义由Amoeba代理的数据库如何连接,比如最基础的:主机IP、端口、Amoeba使用的用户名和密码等等。
Amoeba for mysql读写分离主要涉及两个文件:/usr/local/amoeba/conf/dbServers.xml和/usr/local/amoeba/conf/amoeba.xml
abstractServer配置

  1. <dbServer name="abstractServer" abstractive="true">
  2. <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">
  3. <property name="manager">${defaultManager}</property>
  4. <property name="sendBufferSize">64</property>
  5. <property name="receiveBufferSize">128</property>
  6.  
  7. <!-- mysql port -->
  8. <property name="port">3306</property>
  9.  
  10. <!-- mysql schema -->
  11. <property name="schema">dbname</property>
  12.  
  13. <!-- mysql user -->
  14. <property name="user">root</property>
  15.  
  16. <!-- mysql password -->
  17. <property name="password">root</property>
  18.  
  19. </factoryConfig>
  20.  
  21. <poolConfig class="com.meidusa.amoeba.net.poolable.PoolableObjectPool">
  22. <property name="maxActive">500</property>
  23. <property name="maxIdle">500</property>
  24. <property name="minIdle">10</property>
  25. <property name="minEvictableIdleTimeMillis">600000</property>
  26. <property name="timeBetweenEvictionRunsMillis">600000</property>
  27. <property name="testOnBorrow">true</property>
  28. <property name="testWhileIdle">true</property>
  29. </poolConfig>
  30. </dbServer>

此部分定义真实mysql服务器的端口,数据库名称,mysql用户及密码。

主从数据库定义:

  1. <dbServer name="Master" parent="abstractServer">
  2. <factoryConfig>
  3. <!-- mysql ip -->
  4. <property name="ipAddress">192.168.0.1</property>
  5. </factoryConfig>
  6. </dbServer>
  7. <dbServer name="Slave1" parent="abstractServer">
  8. <factoryConfig>
  9. <!-- mysql ip -->
  10. <property name="ipAddress">192.168.0.2</property>
  11. </factoryConfig>
  12. </dbServer>
  13. <dbServer name="Slave2" parent="abstractServer">
  14. <factoryConfig>
  15. <!-- mysql ip -->
  16. <property name="ipAddress">192.168.0.3</property>
  17. </factoryConfig>
  18. </dbServer>
  19. <dbServer name="virtualSlave" virtual="true">
  20. <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">
  21. <!-- Load balancing strategy: 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA-->
  22. <property name="loadbalance">1</property>
  23.  
  24. <!-- Separated by commas,such as: server1,server2,server1 -->
  25. <property name="poolNames">Slave1,Slave2</property>
  26. </poolConfig>
  27. </dbServer>

此部分定义主服务器,从服务器,及从服务器连接池。这里只定义数据库地址,它们的用户及密码就是上面的abstractServer里的设置。注意用来连接真实mysql服务器的用户必须拥有远程连接权限。

4.2 /usr/local/amoeba/conf/amoeba.xml配置,此文件定义了amoeba代理的相关配置
amoeba连接验证配置:

  1. <property name="authenticator">
  2. <bean class="com.meidusa.amoeba.mysql.server.MysqlClientAuthenticator">
  3.  
  4. <property name="user">root</property>
  5.  
  6. <property name="password">root</property>
  7.  
  8. <property name="filter">
  9. <bean class="com.meidusa.amoeba.server.IPAccessController">
  10. <property name="ipFile">${amoeba.home}/conf/access_list.conf</property>
  11. </bean>
  12. </property>
  13. </bean>
  14. </property>

这里定义连接amoeba时用来验证的用户及密码。

读写分离配置:

  1. <property name="defaultPool">Master</property>
  2. <property name="writePool">Master</property>
  3. <property name="readPool">virtualSlave</property>

defaultPool:配置了默认的数据库节点,一些除了SELECTUPDATEINSERTDELETE的语句都会在defaultPool执行。
writePool :配置了数据库写库,通常配为Master,如这里就配置为之前定义的Master数据库。
readPool :配置了数据库读库,通常配为Slave或者Slave组成的数据库池,如这里就配置之前的virtualSlave数据库池。

5.amoeba启动

  1. # amoeba start //此命令以前台的方式启动,会输出启动时的信息,检查没有错误信息后,中断,并后台运行:
  2. # amoeba start & //后台运行

6.测试
在amoeba上登8066端口跟amoeba远程登陆主mysql服务器效果一样。

  1. # /usr/local/mysql/bin/mysql -uroot -p123456 -h127.0.0.1 -P8066
  2. # /usr/local/mysql/bin/mysql -uroot -p123456 -h192.168.45.7 -P3306

附录:
1.启动amoeba时出现The stack size specified is too small, Specify at least 160k
#vim /usr/loca/amoeba/bin/amoeba文件,修改 DEFAULT_OPTS=”-server -Xms256m -Xmx256m -Xss128k”
为 DEFAULT_OPTS=”-server -Xms256m -Xmx256m -Xss256k”
保存,再次启动即可

2.amoeba查询数据库时出现:java.util.NoSuchElementException: Could not create a validated object, cause: ValidateObject failed

  1. > select * from user;
  2. ERROR 2013 (HY000): Lost connection to MySQL server during query
  3. mysql> java.util.NoSuchElementException: Could not create a validated object, cause: ValidateObject failed
  4. at org.apache.commons.pool.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:1191)
  5. at com.meidusa.amoeba.net.poolable.GenericObjectPool.borrowObject(GenericObjectPool.java:381)
  6. at com.meidusa.amoeba.mysql.handler.CommandMessageHandler.startSession(CommandMessageHandler.java:633)
  7. at com.meidusa.amoeba.mysql.handler.MySqlCommandDispatcher.handleMessage(MySqlCommandDispatcher.java:123)
  8. at com.meidusa.amoeba.mysql.net.MysqlClientConnection$2.run(MysqlClientConnection.java:291)
  9. at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
  10. at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
  11. at java.lang.Thread.run(Thread.java:662)

仔细检查dbServers.xml配置后发现factoryConfig中 password默认是被注释掉的,取消注释后正常。

  1. # vim /usr/local/amoeba/conf/dbServers.xml,删除<!-- mysql password和后面的-->
  2. <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">
  3. <property name="manager">${defaultManager}</property>
  4. <property name="sendBufferSize">64</property>
  5. <property name="receiveBufferSize">128</property>
  6. <!-- mysql port -->
  7. <property name="port">3306</property>
  8. <!-- mysql schema -->
  9. <property name="schema">test</property>
  10. <!-- mysql user -->
  11. <property name="user">root</property>
  12. <!-- mysql password
  13. <property name="password">password</property>
  14. -->
  15. </factoryConfig>

使用Amoeba 实现MySQL DB 读写分离

 

Amoeba(变形虫)项目是一个开源框架,于2008年开始发布一款 Amoeba for Mysql软件;

这个软件致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当SQL路由功能,专注于分布式数据库代理层(Database Proxy)开发;位于 Client、DB Server(s)之间,对客户端透明;

===================================================================

1 简介

2 准备

2.1 时间同步

2.2 配置MySQL主从复制架构

3 ameoba安装配置

3.1 安装配置JDK

3.2 安装ameoba

3.3 配置ameoba

3.4 使用验证

3.5 后期扩展

4 问题记录

===================================================================

1 简介

Amoeba(变形虫)项目是一个开源框架,于2008年开始发布一款 Amoeba for Mysql软件;

这个软件致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当SQL路由功能,专注于分布式数据库代理层(Database Proxy)开发;位于 Client、DB Server(s)之间,对客户端透明;

具有负载均衡、高可用性、SQL 过滤、读写分离、可路由相关的请求到目标数据库、可并发请求多台数据库并合并结果;

通过Amoeba你能够完成多数据源的高可用、负载均衡、数据切片的功能,目前Amoeba已在很多企业的生产线上面使用;

2 准备

2.1 时间同步

  1. # crontab -e
  2. # Dscrip: Time Sync
  3. # CTime: 2014.03.23
  4. */5 * * * * /usr/sbin/ntpdate 172.16.0.1 &>/dev/null

2.2 配置MySQL主从复制架构

详见博文"MariaDB 主从复制"

 

3 ameoba安装配置

3.1 安装配置JDK

  1. chmod +x jdk-6u31-linux-x64-rpm.bin
  2. vi /etc/profile.d/java.sh # 采用bin文件安装jdk
  3. export JAVA_HOME=/usr/java/latest
  4. export PATH=$JAVA_HOME/bin:$PATH

3.2 安装ameoba

  1. mkdir /usr/local/amoeba
  2. tar xf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba # 使用二进制程序文件安装amoeba
  3. cd /usr/local/amoeba
  4. bin/amoeba start # 前台运行
  5. nohup /usr/local/amoeba/bin/amoeba start & # 后台运行
  6. mysql -h127.0.0.1 -uroot -p -P8066 # amoeba默认监听端口为8066

3.3 配置ameoba

  1. cd /usr/local/amoeba/conf
  2. vi ameoba.xml # 前端定义配置文件
  3. # 修改ameoba前端监听端口
  4. <service name="Amoeba for Mysql" class="com.meidusa.amoeba.net.ServerableConnectionManager">
  5. <property name="port">3306</property> # 默认端口是8066,修改为3306,便于实现前端程序连接数据库的透明性
  6. # 修改连接amoeba接口的认证信息
  7. <property name="authenticator">
  8. <bean class="com.meidusa.amoeba.mysql.server.MysqlClientAuthenticator">
  9. <property name="user">root</property>
  10. <property name="password">mypass</property> # 添加登录密码
  11. # 查询路由设置
  12. <queryRouter class="com.meidusa.amoeba.mysql.parser.MysqlQueryRouter">
  13. <property name="ruleLoader">
  14. <bean class="com.meidusa.amoeba.route.TableRuleFileLoader">
  15. <property name="ruleFile">${amoeba.home}/conf/rule.xml</property>
  16. <property name="functionFile">${amoeba.home}/conf/ruleFunctionMap.xml</property>
  17. </bean>
  18. </property>
  19. <property name="sqlFunctionFile">${amoeba.home}/conf/functionMap.xml</property>
  20. <property name="LRUMapSize">1500</property>
  21. <property name="defaultPool">master</property> # 设定默认节点
  22. <property name="writePool">master</property> # 设定可写节点,节点定义见dbServers.xml文件
  23. <property name="readPool">readservers</property> # 设定只读池,可配置多个slave节点
  24. <property name="needParse">true</property>
  25. </queryRouter>
  26. vi dbServers.xml # 后端节点配置文件
  27. # 定义抽象服务器,为每个后端MySQL服务器提供默认连接配置
  28. <dbServer name="abstractServer" abstractive="true">
  29. <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">
  30. <property name="manager">${defaultManager}</property>
  31. <property name="sendBufferSize">64</property>
  32. <property name="receiveBufferSize">128</property>
  33. <property name="port">3406</property>
  34. <property name="schema">test</property>
  35. <property name="user">root</property>
  36. <property name="password">magedu</property>
  37. </factoryConfig>
  38. # 定义后端MySQL的IP地址,一个master,一个slave
  39. <dbServer name="master" parent="abstractServer">
  40. <factoryConfig>
  41. <property name="ipAddress">192.168.0.45</property>
  42. </factoryConfig>
  43. </dbServer>
  44. <dbServer name="slave" parent="abstractServer">
  45. <factoryConfig>
  46. <property name="ipAddress">192.168.0.46</property>
  47. </factoryConfig>
  48. </dbServer>
  49. # 定义虚拟服务器组,即只读池readservers
  50. <dbServer name="readservers" virtual="true">
  51. <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">
  52. <property name="loadbalance">1</property>
  53. <property name="poolNames">master,slave</property>
  54. </poolConfig>
  55. </dbServer>
 

3.4 使用验证

在主库上授权:

  1. MariaDB [(none)]> grant all on *.* to'root'@'172.16.%.%' identified by 'magedu';
  2. Query OK, 0 rows affected (0.00 sec)
  3. MariaDB [(none)]> grant all on *.* to'root'@'%mysql.com' identified by 'magedu'; # 这里的密码应该与dbServer.xml中的数据库密码一致
  4. Query OK, 0 rows affected (0.00 sec)
  5.  
  6. MariaDB [(none)]> flush privileges;
  7. Query OK, 0 rows affected (0.00 sec)
  1. # 登录验证
  2. [root@mysql conf]# mysql -h127.0.0.1 -uroot -p -P3306
  3. Enter password:
  4. Welcome to the MariaDB monitor. Commands end with ; or \g.
  5. Your MySQL connection id is 2097086015
  6. Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution
  7. Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.
  8. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  9. MySQL [(none)]> show master status;
  10. +------------------+----------+--------------+------------------+
  11. | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
  12. +------------------+----------+--------------+------------------+
  13. | mysql-bin.000030 | 326 | | |
  14. +------------------+----------+--------------+------------------+
  15. 1 row in set (0.00 sec)
  16. MySQL [(none)]>
  17. # 读写验证
  18. [root@mysql conf]# mysql -h127.0.0.1 -uroot -p -P3306
  19. Enter password:
  20. Welcome to the MariaDB monitor. Commands end with ; or \g.
  21. Your MySQL connection id is 2097086015
  22. Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution
  23. Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.
  24. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  25. MySQL [(none)]> create database amoeba_test;
  26. Query OK, 1 row affected (0.04 sec)
  27. MySQL [(none)]>
  28. [root@mysql bin]# mysql -h127.0.0.1 -uroot -p -P3406
  29. Enter password:
  30. Welcome to the MariaDB monitor. Commands end with ; or \g.
  31. Your MariaDB connection id is 33
  32. Server version: 10.0.10-MariaDB-log Source distribution
  33. Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.
  34. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  35. MariaDB [(none)]> show databases;
  36. +--------------------+
  37. | Database |
  38. +--------------------+
  39. | amoeba_test |
  40. | information_schema |
  41. | mysql |
  42. | performance_schema |
  43. | test |
  44. +--------------------+
  45. 9 rows in set (0.01 sec)
  46. MariaDB [(none)]>
  47. # 从amoeba接口登录创建数据库amoeba_test后,再从主库的接口中去查询数据库已创建,说明写入确实是落在了主库节点上;
  48. # 若要验证ameoba对于读操作的调度,则需要暂时停止从库的复制操作,然后在主库上更新数据,这样从ameoba读取数据将出现不一致的情况;
 

3.5 后期扩展

利用MMM双主复制架构+Amoeba代理,可以实现对MySQL的高可用性和高性能;

关于MMM的内容参加博文"MySQL Scale Out"

4 问题记录

现象:使用mysql -uroot -p -P8066命令始终无法连接进入ameoba的配置接口,一直都是进入mysql数据库的配置接口

原因:在测试环境下,ameoba和mysql的主库都部署在同一台主机上,当启动ameoba服务后,即使指定-P8066连接,mysql客户端还是默认采用可被识别的socket文件(/tmp/mysql.sock)连接,同样指定-hlocalhost也是一样的;

当使用mysql命令连接mysqld时:

  • 连接主机为localhost或不指定时,mysql会采用Unix Socket的连接方式;

  • 连接主机为127.0.0.1时,mysql会采用TCP的方式连接;

解决方法:指定-h127.0.0.1连接即可,即mysql -h127.0.0.1 -uroot -p -P8066

Amoeba是一个类似MySQL Proxy的分布式数据库中间代理层软件,是由陈思儒开发的一个开源的java项目的更多相关文章

  1. 分布式版本库——Windows下Git的环境部署以及在GitHub上开源自己的项目

    分布式版本库--Windows下Git的环境部署以及在GitHub上开源自己的项目 这几天着实忙的焦头烂额,可惜不是搞技术,今天周日,难得闲下来,写篇大家都想学习的Git教程,其实廖雪峰老师的网站已经 ...

  2. TiDB:支持 MySQL 协议的分布式数据库解决方案

    [编者按]TiDB 是国内 PingCAP 团队开发的一个分布式 SQL 数据库.其灵感来自于 Google 的 F1,TiDB 支持包括传统 RDBMS 和 NoSQL 的特性.在国内 ITOM 管 ...

  3. MySQL Proxy和 Amoeba 工作机制浅析

    MySQL Proxy处于客户端应用程序和MySQL服务器之间,通过截断.改变并转发客户端和后端数据库之间的通信来实现其功能,这和WinGate 之类的网络代理服务器的基本思想是一样的.代理服务器是和 ...

  4. Amoeba:开源的分布式数据库Porxy解决方案

    http://www.biaodianfu.com/amoeba.html 什么是Amoeba? Amoeba(变形虫)项目,该开源框架于2008年 开始发布一款 Amoeba for Mysql软件 ...

  5. MySQL分布式数据库架构:分库、分表、排序、分页、分组、实现教程

    MySQL分库分表总结: 单库单表 : 单库单表是最常见的数据库设计,例如,有一张用户(user)表放在数据库db中,所有的用户都可以在db库中的user表中查到. 单库多表 : 随着用户数量的增加, ...

  6. net Core 使用MyCat分布式数据库,实现读写分离

    net Core 使用MyCat分布式数据库,实现读写分离 目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 MyCat2.0版本很快就发布了,关于MyCat的动态和一些问题, ...

  7. 五分钟DBA:浅谈伪分布式数据库架构

    [IT168 技术]12月25日消息,2010互联网行业技术研讨峰会今日在上海华东理工大学召开.本次峰会以“互联网行业应用最佳实践”为主题,定位于互联网架构设计.应用开发.应用运维管理,同时,峰会邀请 ...

  8. 【巨杉数据库SequoiaDB】省级农信国产分布式数据库应用实践

    本文转载自<金融电子化> 原文链接:https://mp.weixin.qq.com/s/WGG91Rv9QTBHPsNVPG8Z5g 随着移动互联网的迅猛发展,分布式架构在互联网IT技术 ...

  9. 腾讯云分布式数据库TDSQL在银行传统核心系统中的应用实践

    本文是腾讯云TDSQL首席架构师张文在腾讯云Techo开发者大会现场的演讲实录,演讲主题是<TDSQL在银行传统核心系统中的应用实践>. 我是TDSQL架构师张文,同时也是TDSQL的开发 ...

随机推荐

  1. (转)织梦cms首页添加digg顶一下的修改方法

    现在把文章内容页拔的顶拔出来.分享一下让各位需要的朋友参考使用(特别注意:红色的是修改的地方)第一步:把顶踩的js和ajax提取出来,放在想要使用的页面用(比如:首页)以下是内容页顶踩用的js.提取出 ...

  2. Visual Studio 2013 无法启动 IIS Express 的解决办法

    关于 ASP.NET Web 开发服务器.本地 IIS和 IIS Express 的区别,请参见<VS2013无法启动IIS Express Web的解决办法>,此文章最后提到的部分,即是 ...

  3. Mavne + Spring整合CXF

    http://blog.csdn.net/xiongyu777888/article/details/23787615(没毛病) http://blog.csdn.net/hbsong75/artic ...

  4. iOS之多线程开发NSThread、NSOperation、GCD

    原文出处: 容芳志的博客   欢迎分享原创到伯乐头条 简介iOS有三种多线程编程的技术,分别是:(一)NSThread(二)Cocoa NSOperation(三)GCD(全称:Grand Centr ...

  5. javaScript 手写图片轮播

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. [转]Traits 编程技法+模板偏特化+template参数推导+内嵌型别编程技巧

    STL中,traits编程技法得到了很大的应用,了解这个,才能一窥STL奥妙所在. 先将自己所理解的记录如下: Traits技术可以用来获得一个 类型 的相关信息的. 首先假如有以下一个泛型的迭代器类 ...

  7. BroadcastReceiver监听电量变化

    用BroadcastReceiver监听电量的变化,可以实现BroadcastReceiver接收电量变化的广播,然后获取电量百分比信息. BatteryChangedReceiver.java pu ...

  8. 各种开源协议介绍 BSD、Apache Licence、GPL V2 、GPL V3 、LGPL、MIT

    现今存在的开源协议很多,而经过Open Source Initiative组织通过批准的开源协议目前有58种(http://www.opensource.org/licenses /alphabeti ...

  9. jQuery中的模拟操作

    jQuery中的模拟操作主要是通过trigger来触发,相当于页面加载完成后不需要用户点击按钮,就可以自动触发页面中的相关事件. trigger(type,[data])可以用来模拟触发自定义事件的触 ...

  10. ucenter 通信原理

    1.用户登录discuz,通过logging.php文件中的函数uc_user_login对post过来的数据进行验证,也就是对username和password进行验证. 2.如果验证成功,将调用位 ...