百度架构师是怎样搭建MySQL分布式集群?

一、什么是MySQL集群node

MySQL集群是一个无共享的(shared-nothing)、分布式节点架构的存储方案,其目的是提供容错性和高性能。mysql

数据更新使用读已提交隔离级别(read-committedisolation)来保证全部节点数据的一致性,使用两阶段提交机制(two-phasedcommit)保证全部节点都有相同的数据(若是任何一个写操做失败,则更新失败)。sql

无共享的对等节点使得某台服务器上的更新操做在其余服务器上当即可见。传播更新使用一种复杂的通讯机制,这一机制专用来提供跨网络的高吞吐量。数据库

经过多个MySQL服务器分配负载,从而最大程序地达到高性能,经过在不一样位置存储数据保证高可用性和冗余。服务器

须要更多MySQL集群知识的能够订阅我哦网络

百度架构师是怎样搭建MySQL分布式集群?

二、名称概念架构

MySQL集群有以下三层:分布式

应用程序层:负责与mysql服务器通讯的各类应用程序。性能

Mysql服务器层:处理SQL命令,并与NDB存储引擎通讯和Mysql服务器。cdn

NDB集群组件层:NDB集群组件有时也称数据节点,负责处理查询,而后将结果返回给mysql服务器。

其中MySQL数据库集群主要包括以下三部分:

1) SQL节点(SQL node - 下图对应为 mysqld):分布式数据库。包括自身数据和查询中心结点数据

2) 数据节点(Data node - ndbd):集群共享数据(内存中)

3) 管理服务器(Management Server - ndb_mgmd):管理集群 SQL node,Data node

拓扑结构图以下所示:

百度架构师是怎样搭建MySQL分布式集群?

百度架构师是怎样搭建MySQL分布式集群?

欢迎关注,欢迎留言探讨。

相关文章
相关标签/搜索