做者 陈彩华
文章转载交流请联系 caison@aliyun.com
复制代码
最近学习了阿里资深技术专家李运华的架构设计关于读写分离的教程,很有收获,总结一下。前端
本文主要介绍高性能数据库集群读写分离相关理论,基本架构,涉及的复杂度问题以及常看法决方案。mysql
基本架构图: sql
**读写分离不是银弹,并非一有性能问题就上读写分离,**而是应该先优化,例如优化慢查询,调整不合理的业务逻辑,引入缓存查询等只有肯定系统没有优化空间后才考虑读写分离集群数据库
如何将读写操做区分开来,而后访问不一样的数据库服务器?后端
基本架构图 缓存
业界开源实现bash
基本架构图服务器
业界开源实现markdown
MySQL Router是轻量级的中间件,可在应用程序和任何后端MySQL服务器之间提供透明路由。它能够用于各类各样的用例,例如经过有效地将数据库流量路由到适当的后端MySQL服务器来提供高可用性和可伸缩性。可插拔架构还使开发人员可以扩展MySQL Router以用于自定义用例。架构
基于MySQL Router能够实现读写分离,故障自动切换,负载均衡,链接池等功能。
MySQL官方提供的MySQL Proxy
360开源的Atlas
Atlas是由平台部基础架构团队开发维护的一个基于MySQL协议的数据中间层项目。它是在mysql-proxy的基础上,对其进行了优化,增长了一些新的功能特性。
功能 | Sharding-JDBC | TDDL | Amoeba | Cobar | MyCat |
---|---|---|---|---|---|
基于客户端仍是服务端 | 客户端 | 客户端 | 服务端 | 服务端 | 服务端 |
分库分表 | 有 | 有 | 有 | 有 | 有 |
MySQL交互协议 | JDBC Driver | JDBC Driver | 前端用NIO,后端用JDBC Driver | 前端用NIO,后端用BIO | 先后端均用NIO |
支持的数据库 | 任意 | 任意 | 任意 | MySQL | 任意 |
参考