Amoeba for MySQL 基本介绍

Amoeba  for  MySQL 简要介绍

 

 转载请注明原文出处:http://www.minunix.com/2013/11/amoeba-introduction/                    作者:MinUnix

 文档地址:文档书写中,稍后公布。。谢谢您的光顾

 Amoeba简介

Amoeba 是阿里巴巴的技术陈思儒开始的一个开源项目,它是分布式数据库Proxy解决方案。Amoeba框架是基于Java SE 1.5开发的,在安装Amoeba之前需要先安装Java环境。经验证,Amoeba在Java SE 1.5和Java SE 1.6上能正常运行。

Amoeba的产品:

Amoeba for MySQL

Amoeba for Aladdin

Amoeba for MongoDB

以下主要介绍Amoeba for mysql:

Amoeba for MySQL致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当query 路由功能,专注 分布式数据库 proxy 开发。座落与Client、DB Server(s)之间。对客户端透明。具有负载均衡、高可用性、Query过滤、读写分离、可路由相关的query到目标数据库、可并发请求多台数据库合并结果。 在Amoeba上面你能够完成多数据源的高可用、负载均衡、数据切片的功能。目前在很多企业的生产线上面使用。

那么Amoeba for mysql 对客户端程序来说是什么呢? 我们就当它是mysql吧,它是一个虚拟的mysql,对外提供mysql协议。客户端连接amoeba就象连接mysql一样。在amoeba内部需要配置相关的认证属性。

<a href="https://i-blog.csdnimg.cn/blog_migrate/7ccd93fe42c4a01d8359e4ae47ccdb40.png" class="cboxElement" rel="example4" 524"="" style="text-decoration: none; color: rgb(1, 150, 227);">

 

Amoeba for mysql与Mysql Proxy 的比较:

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

Amoeba for MySQL的优点:

1. 降低数据切分带来的复杂多数据库结构

2. 提供切分规则并降低数据切分规则给应用带来的影响

3. 降低db 与客户端的连接数

4. 读写分离

转载请注明原文出处:http://www.minunix.com/2013/11/amoeba-introduction/                    作者:MinUnix

Amoeba for MySQL的缺点:

1. Amoeba for MySQL不支持事务:其实,分布式事务的问题是所有数据库中间层普遍面临的问题,不是Amoeba独有的问题;目前通常的解决办法是,将事务拆分成几个单数据库内的小事务,由应用程序进行总控。

2. Amoeba for MySQL不支持跨节点JOIN:同样,这个问题也不是Amoeba独有的,通常的解决办法是由应用程序先从一个节点取出数据,然后由应用程序去其他节点JOIN。

3. Amoeba for MySQL不支持跨节点排序:这个问题也不是Ameoba独有的,通常的解决办法是由应用程序从多个节点中取出数据,然后进行排序。

4. Amoeba for MySQL不适合返回大量(超过10万)数据的查询。

5. Amoeba for MySQL不支持分库分表,只能做到分数据库实例。

 

为何使用Amoeba :

随着传统的数据库技术日趋成熟、计算机网络技术的飞速发展和应用范围的扩充,数据库应用已经普遍建立于计算机网络之上。这时集中式数据库系统表现出它的不足:集中式处理,势必造成性能瓶颈;应用程序集中在一台计算机上运行,一旦该计算机发生故障,则整个系统受到影响,可靠性不高;集中式处理引起系统的规模和配置都不够灵活,系统的可扩充性差。在这种形势下,集中式数据库将向分布式数据库发展。而Amoeba的透明、简易配置及多个优点使其成为分布式数据库代理产品中的优秀选择。

 

转载请注明原文出处:http://www.minunix.com/2013/11/amoeba-introduction/                    作者:MinUnix

后续会介绍Amoeba for MySQL 读写分离的安装配置,请继续关注MinUnix


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值