数据切分及整合方案

数据切分及整合方案

ID:15032727

大小:151.50 KB

页数:6页

时间:2018-08-01

数据切分及整合方案_第1页
数据切分及整合方案_第2页
数据切分及整合方案_第3页
数据切分及整合方案_第4页
数据切分及整合方案_第5页
资源描述:

《数据切分及整合方案》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、数据切分及整合方案利用MySQLProxy实现数据切分及整合MySQLProxy是MySQL官方提供的一个数据库代理层产品,和MySQLServer一样,它也是一个基于GPL开源协议的开源产品。可用来监视、分析或传输它们之间的通讯信息。它的灵活性允许最大限度地使用它,目前具备的功能主要有连接路由、Query分析、Query过滤和修改、负载均衡,以及基本的HA机制等。实际上,MySQLProxy本身并不具有上述所有的功能,而是提供了实现上述功能的基础。要实现这些功能,还须要我们自行编写LUA脚本。MySQLProxy实际上是在客户端请求与MySQLServer之

2、间建立了一个连接池。所有客户端请求都发向MySQLProxy,然后经由MySQLProxy进行相应的分析,判断出是读操作还是写操作,分发至对应的MySQLServer上。对于多节点Slave集群,也可以起到负载均衡的效果。如MySQLProxy基本架构图(图14-4): (点击查看大图)图14-4 MySQLProxy架构通过上面的架构简图,可以清晰地看到MySQLProxy在实际应用中所处的位置,以及能做的基本事情。MySQLProxy详细的实施细则在MySQL官方文档中有非常详细的介绍和示例,感兴趣的读者朋友可以直接从MySQL官方网站免费下载或者在线阅读

3、,这里就不赘述。利用Amoeba实现数据切分及整合Amoeba是一个基于Java开发的,专注于解决分布式数据库数据源整合Proxy程序的开源框架,基于GPL3开源协议。目前,Amoeba已经具有Query路由、Query过滤、读写分离、负载均衡及HA机制等相关内容,如图14-5所示。Amoeba主要解决以下几个问题:(1)数据切分后复杂数据源整合;(2)提供数据切分规则并降低数据切分规则给数据库带来的影响;(3)降低数据库与客户端的连接数;(4)读写分离路由。 (点击查看大图)图14-5 AmoebaForMySQL架构可以看出,Amoeba所做的事情,正好就

4、是通过数据切分来提升数据库的扩展性所需要的。Amoeba并不是一个代理层的Proxy程序,而是一个开发数据库代理层Proxy程序的框架,目前基于Amoeba所开发的Proxy程序有AmoebaForMySQL和AmoebaForAladin两个。AmoebaForMySQL是专门针对MySQL数据库的解决方案,前端应用程序请求的协议及后端连接的数据源数据库都必须是MySQL。对于客户端的任何应用程序来说,AmoebaForMySQL和一个MySQL数据库没有什么区别,任何使用MySQL协议的客户端请求,都可以被AmoebaForMySQL解析并进行相应的处理。

5、AmoebaFor可以告诉我们AmoebaForMySQL的架构信息(出自Amoeba开发者博客):AmoebaForAladin则是一个适用更为广泛、功能更为强大的Proxy程序。它可以同时连接不同数据库的数据源为前端应用程序提供服务,但是仅仅接受符合MySQL协议的客户端应用程序请求。也就是说,只要前端应用程序通过MySQL协议连接上来,AmoebaForAladin会自动分析Query语句,根据Query语句中所请求的数据来自动识别出该Query的数据源是在什么类型数据库的哪一个物理主机上。AmoebaForAladdin架构图(图14-6)展示了Amo

6、ebaForAladin的架构细节(出自Amoeba开发者博客)。乍一看,两者好像完全一样嘛。细看才会发现两者主要的区别仅在于通过MySQLProtocalAdapter处理之后,根据分析结果判断出数据源数据库,然后选择特定的JDBC驱动和相应协议连接后端数据库。其实通过上面两个架构图大家可能已经发现了Amoeba的特点,它只是一个开发框架,我们除了选择它已经提供的ForMySQL和ForAladin这两款产品之外,还可以基于自身的需求进行二次开发,得到更适合自己应用特点的Proxy程序。但对于使用MySQL数据库来说,不论是AmoebaForMySQL还是A

7、moebaForAladin都可以很好地使用。当然,考虑到任何一个系统越是复杂,其性能肯定就会有一定的损失,维护成本自然也会更高一些。所以,在仅仅须要使用MySQL数据库的时候,还是建议使用AmoebaForMySQL。AmoebaForMySQL的使用非常简单,所有的配置文件都是标准的XML文件,总共有4个,分别如下:amoeba.xml--主配置文件,配置所有数据源及Amoeba自身的参数;rule.xml--配置所有Query路由规则的信息;functionMap.xml--配置用于解析Query中的函数所对应的Java实现类;rullFunctionM

8、ap.xml--配置路由规则中需要使用

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。