MySQL集群结构

Posted 云容灾备份安全治理

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL集群结构相关的知识,希望对你有一定的参考价值。

以下是一个简单的mysql集群拓扑图:

1.MySQL中间件:对MySQL Server的读写操作进行路由(即读写分离);分库分表(sharding)

  • (1).MySQL Router:MySQL官方提供的轻量级MySQL代理(路由),只提供读写分离功能,前身为SQL Proxy。

  • (2).ProxySQL:类似于MySQL Router,轻量级MySQL代理,提供读写分离功能,也支持一些sharding功能。有percona版和官方版两个版本。

  • (3).MaxScale:MariaDB的中间件,和MySQL Router、ProxySQL类似。

    • 这三者类似,都是轻量级数据库中间件。

  • (4).Amoeba、Cobar、MyCAT:提供很多功能,最主要的功能包括读写分离、sharding。

    • 这三者的渊源较深,都是开源的。Amoeba后继无人,于是Cobar出来,Cobar后继无人,加上2013年出现了一次较严重的问题,于是MyCAT站在Cobar的肩膀上出来了。

2.MySQL主从复制的高可用:至少要实现主从切换或故障时选举新master节点

  • (1).MMM:淘汰了,在一致性和高并发稳定性等方面有些问题。

  • (2).MHA:有些人还在用,但也有些问题,也是趋于淘汰的MySQL主从高可用方案。

  • (3).Galera:引领时代的主从复制高可用技术。

  • (4).MariaDB Galera Cluster:MariaDB对Galera的实现。

  • (5).PXC:Percona XtraDB Cluster,是Percona对Galera的自我实现,用的人很多。

  • (6).GR:Group Replication,MySQL官方提供的组复制技术(MySQL 5.7.17引入的技术),基于Paxos算法。

    • MariaDB Galera Cluster、PXC、GR是类似的,都各有优点。但GR是革命性的,基于原生复制技术,据传很多方面都优于PXC。

    • MariaDB Galera Cluster、PXC、GR为了安全性和性能考虑,做出了很多强制性的限制。例如基于GTID复制、只能InnoDB表,每表都必须有主键等。要使用它们提供主从复制的高可用,必须要了解它们的各项限制。


以上是关于MySQL集群结构的主要内容,如果未能解决你的问题,请参考以下文章

MySQL InnoDB Cluser | Mysql 5.7 集群

MYSQL 的集群

MySQL集群架构05分组复制架构和NDB集群架构

MYSQL-MMM主从同步部署mysql高用集群

Mysql集群介绍

配置MySQL高可用集群MHA