【赵渝强老师】MySQL Cluster

本文涉及的产品
PolarSearch,搜索节点 4核8GB
PolarDB Agent Flow,2核4GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: MySQL NDB Cluster是高可用、高性能的分布式数据库系统,基于NDB存储引擎,支持自动分区、实时处理、多地域复制与ACID事务。适用于电信、金融等关键业务场景,具备动态扩展与故障自愈能力。(239字)

b453.png

MySQL Cluster(现官方称:MySQL NDB Cluster)是一个高可用、高性能的数据库解决方案,它通过分布式数据存储来提高读写性能和数据冗余度。MySQL Cluster采用NDB(Network Database)存储引擎,支持实时处理大量并发操作,特别适合于电信、金融等需要高可靠性和高性能的行业应用。


视频讲解如下


一、 MySQL Cluster的功能特性

  • 高可用

MySQL Cluster具有内置的高可用性功能,可以自动检测和恢复故障。它支持故障检测和节点恢复,以确保集群中的数据和服务可用性。

  • 分布式存储

NDB存储引擎支持将数据分布在多个节点上,实现了数据的分布式存储。这意味着数据可以水平扩展,从而提高了存储容量和性能。

  • 实时处理

MySQL Cluster旨在支持实时数据处理,特别适用于需要低延迟和高吞吐量的应用程序,如电信、在线游戏和金融领域。

  • 自动分区

NDB存储引擎支持自动分区,可以根据数据分布自动将数据分割成多个分区,以实现负载均衡和高性能。

  • 动态扩展

MySQL Cluster支持动态添加和删除节点,因此可以根据需求扩展集群。

  • 事务支持

MySQL Cluster支持ACID(原子性、一致性、隔离性和持久性)事务,确保数据的一致性和可靠性。

  • 并行查询

NDB存储引擎支持并行查询,允许同时执行多个查询以提高性能。

  • 多地域复制

MySQL Cluster支持跨地域的数据复制,使数据在不同地理位置之间进行同步,以提高数据冗余和可用性。


二、 MySQL Cluster的体系架构


MySQL Cluster的体系架构如下:

image.png


其中:


  • SQL Node

SQL节点主要负责实现一个数据库在存储层之上的所有事情,比如:连接管理,Query优化和响应,Cache管理等等,只有存储层的工作交给了数据节点去处理。也就是说,在MySQL Cluster环境中的SQL Node,可以被认为是一个不需要提供任何存储引擎的MySQL服务器,只要用于执行SQL语句。


  • Management Node

管理节点的作用是管理集群中的其他节点,提供配置数据、启动和停止节点以及运行备份等功能。因为这种类型的节点管理其他节点的配置,所以应该首先启动这种类型的节点,然后再启动任何其他节点。使用命令ndb_mgmd启动管理节点。


  • Data Node

数据节点主要实现底层数据存储的功能。每一个数据节点保存完整数据的一个fragment,也就是一个数据分片(或者一份完整的数据),所以只要配置得当,MySQL Cluster在存储层不会出现单点的问题。使用命令ndbd或ndbmtd启动数据节点。


三、 部署MySQL Cluster


下面的表格列举了集群中的节点信息(操作系统:银河麒麟Linux)。

image.png

安装介质信息如下:

mysql-cluster-community-client-8.0.23-1.el8.x86_64.rpm
mysql-cluster-community-client-plugins-8.0.23-1.el8.x86_64.rpm
mysql-cluster-community-common-8.0.23-1.el8.x86_64.rpm
mysql-cluster-community-data-node-8.0.23-1.el8.x86_64.rpm
mysql-cluster-community-libs-8.0.23-1.el8.x86_64.rpm
mysql-cluster-community-management-server-8.0.23-1.el8.x86_64.rpm
mysql-cluster-community-server-8.0.23-1.el8.x86_64.rpm


具体的安装步骤如下:

(1)所有节点关闭防火墙

systemctl stop firewalld
systemctl disable firewalld

(2)所有节点编辑/etc/selinux/config文件关闭SELinux

SELINUX=enforcing
修改为
SELINUX=disabled

(3)所有节点编辑/etc/hosts文件配置主机名与IP地址映射关系

192.168.79.11 node11
192.168.79.12 node12
192.168.79.13 node13
192.168.79.14 node14

(4)所有节点卸载原有mariadb和mysql的库

# 检查是否安装了mariadb
yum list installed | grep mariadb*
# 卸载mariadb
yum remove mariadb* -y
# 检查是否安装了mysql
yum list installed | grep mysql*
# 卸载mysql
yum remove mysql* -y

(5)在node11上安装SQL Node

rpm -ivh mysql-cluster-community-client-plugins-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-common-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-libs-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-client-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-server-8.0.23-1.el8.x86_64.rpm

(6)在node12上安装Management Node和客户端管理工具

rpm -ivh mysql-cluster-community-management-server-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-client-plugins-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-common-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-libs-8.0.23-1.el8.x86_64.rpm
rpm -ivh mysql-cluster-community-client-8.0.23-1.el8.x86_64.rpm

(7)在node13和node14上安装Data Node

rpm -ivh mysql-cluster-community-data-node-8.0.23-1.el8.x86_64.rpm

(8)在node12上配置Management Node

# 创建目录
mkdir -p /var/lib/mysql-cluster/
# 在管理节点上创建配置文件/var/lib/mysql-cluster/config.ini,添加以下内容
[NDBD DEFAULT]
NoOfReplicas=2
DataMemory=80M
IndexMemory=18M
[TCP DEFAULT]
[MYSQLD DEFAULT]
[NDB_MGMD DEFAULT]
[NDB_MGMD]
HostName=node12
DataDir=/var/lib/mysql-cluster
[NDBD]
HostName=node13
DataDir=/usr/local/mysql/data
[NDBD]
HostName=node14
DataDir=/usr/local/mysql/data
[MYSQLD]

(9)在node12上启动Management Node

ndb_mgmd -f /var/lib/mysql-cluster/config.ini --initial
# 输出的信息如下:
MySQL Cluster Management Server mysql-8.0.23 ndb-8.0.23
... [MgmtSrvr] INFO     -- The default config directory '/usr/mysql-cluster' does not exist. Trying to create it...
... [MgmtSrvr] INFO     -- Sucessfully created config directory
... [MgmtSrvr] WARNING  -- at line 4: [DB] IndexMemory is deprecated, will use Number bytes on each ndbd(DB) node allocated for storing indexes instead

(10)在node13和node14上配置Data Node

# 创建目录
mkdir -p /usr/local/mysql/data
chown -R mysql:mysql /usr/local/mysql/data
# 编辑文件/etc/my.cnf,增加下面的内容
[mysql_cluster]
ndb-connectstring=node12

(11)在node13和node14上启动Data Node

ndbd --initial
# 输出的信息如下:
[root@node13 8]# ndbd --initial
2026-05-14 17:48:36 [ndbd] INFO     -- Angel connected to 'node12:1186'
2026-05-14 17:48:36 [ndbd] INFO     -- Angel allocated nodeid: 2
[root@node14 8]# ndbd --initial
2026-05-14 17:48:39 [ndbd] INFO     -- Angel connected to 'node12:1186'
2026-05-14 17:48:39 [ndbd] INFO     -- Angel allocated nodeid: 3

(12)在node12的Management Node上查看集群的状态信息。

# ndb_mgm
-- NDB Cluster -- Management Client --
ndb_mgm> show
# 输出的信息如下:
Connected to Management Server at: localhost:1186
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=2  @192.168.79.13  (mysql-8.0.23 ndb-8.0.23, Nodegroup: 0, *)
id=3  @192.168.79.14  (mysql-8.0.23 ndb-8.0.23, Nodegroup: 0)
[ndb_mgmd(MGM)] 1 node(s)
id=1  @192.168.79.12  (mysql-8.0.23 ndb-8.0.23)
[mysqld(API)] 1 node(s)
id=4 (not connected, accepting connect from any host)

(13)在node11上配置SQL Node

# 编辑/etc/my.cnf文件,添加以下内容:
[mysqld]
ndbcluster
ndb-connectstring=node12
[mysql_cluster]
ndb-connectstring=node12

(14)在node11上启动SQL Node

systemctl start mysqld

(15)在node12的Management Node上验证集群状态

# ndb_mgm
-- NDB Cluster -- Management Client --
# 查看集群的信息
ndb_mgm> show
# 输出的信息如下:
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=2  @192.168.79.13  (mysql-8.0.23 ndb-8.0.23, Nodegroup: 0, *)
id=3  @192.168.79.14  (mysql-8.0.23 ndb-8.0.23, Nodegroup: 0)
[ndb_mgmd(MGM)] 1 node(s)
id=1  @192.168.79.12  (mysql-8.0.23 ndb-8.0.23)
[mysqld(API)] 1 node(s)
id=4  @192.168.79.11  (mysql-8.0.23 ndb-8.0.23)
# 查看集群的节点信息
ndb_mgm> 1 status
Node 1: connected (Version 8.0.23)
ndb_mgm> 2 status
Node 2: started (mysql-8.0.23 ndb-8.0.23)
ndb_mgm> 3 status
Node 3: started (mysql-8.0.23 ndb-8.0.23)
ndb_mgm> 4 status
Node 4: connected (Version 8.0.23)

(16)在node11的SQL Node上登录MySQL客户端

# 初始密码位于/var/log/mysqld.log文件中
# 登录后修改root用户密码
mysql> alter user root@localhost identified by 'Welcome_1';

(17)执行脚本创建分布式表

create database scott;
use scott
create table dept
(deptno int primary key,
dname varchar(10),
loc varchar(10)
) ENGINE=ndbcluster;
create table emp
(empno int primary key,
ename varchar(10),
job varchar(10),
mgr int,
hiredate varchar(10),
sal int,
comm int,
deptno int,
foreign key(deptno) references dept(deptno)) ENGINE=ndbcluster;
insert into dept values(10,'ACCOUNTING','NEW YORK');
insert into dept values(20,'RESEARCH','DALLAS');
insert into dept values(30,'SALES','CHICAGO');
insert into dept values(40,'OPERATIONS','BOSTON');
insert into emp values(7369,'SMITH','CLERK',7902,'1980/12/17',800,null,20);
insert into emp values(7499,'ALLEN','SALESMAN',7698,'1981/2/20',1600,300,30);
insert into emp values(7521,'WARD','SALESMAN',7698,'1981/2/22',1250,500,30);
insert into emp values(7566,'JONES','MANAGER',7839,'1981/4/2',2975,null,20);
insert into emp values(7654,'MARTIN','SALESMAN',7698,'1981/9/28',1250,1400,30);
insert into emp values(7698,'BLAKE','MANAGER',7839,'1981/5/1',2850,null,30);
insert into emp values(7782,'CLARK','MANAGER',7839,'1981/6/9',2450,null,10);
insert into emp values(7788,'SCOTT','ANALYST',7566,'1987/4/19',3000,null,20);
insert into emp values(7839,'KING','PRESIDENT',-1,'1981/11/17',5000,null,10);
insert into emp values(7844,'TURNER','SALESMAN',7698,'1981/9/8',1500,null,30);
insert into emp values(7876,'ADAMS','CLERK',7788,'1987/5/23',1100,null,20);
insert into emp values(7900,'JAMES','CLERK',7698,'1981/12/3',950,null,30);
insert into emp values(7902,'FORD','ANALYST',7566,'1981/12/3',3000,null,20);
insert into emp values(7934,'MILLER','CLERK',7782,'1982/1/23',1300,null,10);

(18)查询表的分片信息。

mysql> select partition_name,table_rows 
      from information_schema.PARTITIONS 
      where table_name='emp' and table_schema='scott';
# 输出的信息如下:
+----------------+------------+
| PARTITION_NAME | TABLE_ROWS |
+----------------+------------+
| p0             |          1 |
| p1             |         13 |
+----------------+------------+
2 rows in set (0.01 sec)
mysql> select partition_name,table_rows 
       from information_schema.PARTITIONS 
       where table_name='dept' and table_schema='scott';
# 输出的信息如下:
+----------------+------------+
| PARTITION_NAME | TABLE_ROWS |
+----------------+------------+
| p0             |          2 |
| p1             |          2 |
+----------------+------------+
2 rows in set (0.00 sec)
# 从输出的信息可以看出,员工表emp中共有14条数据;
# 其中13条数据被存储在了p1分片上。
# 因此使用员工号empno()主键作为片键发生了数据倾斜。

(19)创建一张新的员工表emp1,并使用员工姓名ename作为主键(片键),并插入数据。

mysql> create table emp1
       (empno int,
       ename varchar(10) primary key,
       job varchar(10),
       mgr int,
       hiredate varchar(10),
       sal int,
       comm int,
       deptno int,
       foreign key(deptno) references dept(deptno)) ENGINE=ndbcluster;
     
mysql> insert into emp1 select * from emp;

(20)查询emp1的数据分片情况

mysql> select partition_name,table_rows 
       from information_schema.PARTITIONS 
       where table_name='emp1' and table_schema='scott';
# 输出的信息如下:
+----------------+------------+
| PARTITION_NAME | TABLE_ROWS |
+----------------+------------+
| p0             |          5 |
| p1             |          9 |
+----------------+------------+
2 rows in set (0.00 sec)
# 此时的数据更加均匀地进行了分布。
相关文章
|
10天前
|
自然语言处理 前端开发 安全
2026 世界杯钓鱼即服务平台攻击机理与防御体系研究
2026世界杯前夕,“Ghost Stadium”中文钓鱼即服务平台发动大规模攻击,涉案4.7–10亿美元,受害超4.7万人,窃取FIFA凭证2500+条,注册恶意域名超4000个。该平台采用React+Layui实现像素级克隆、SSO模拟与多语言适配,构建覆盖社交广告、搜索、IM的立体攻击网络。本文基于实证分析,提出检测、响应、溯源、治理闭环防御体系,强调跨机构协同与动态对抗。(239字)
174 10
|
10天前
|
存储 人工智能 算法
告别无效刷屏!TrendRadar:最快30秒部署的开源热点助手,让你只看真正关心的新闻
TrendRadar 是一个轻量级、易部署的热点新闻聚合与推送工具。它能够从知乎、抖音、B站、微博、百度、华尔街见闻等11个主流平台抓取热搜榜单,然后根据你设定的关键词进行智能筛选,最终将你最关心的内容推送到手机或邮箱。
269 13
 告别无效刷屏!TrendRadar:最快30秒部署的开源热点助手,让你只看真正关心的新闻
|
10天前
|
人工智能 监控 安全
AI客服真的能办事吗?91%的解决率是怎么跑出来的
AI客服解决率从行业平均的50%-60%跃升至91%,背后不是模型参数的堆叠,而是知识、流程、工具和运营四层能力的系统性重构。多数企业卡在"能回答"到"能办事"的跨越上,根源在于把AI客服当问答机器人用,而非当作可执行任务的服务岗位。拆解91.3%解决率的真实路径,关键在知识运营、流程拆解、工具调用和人机协同的闭环设计。
185 3
|
10天前
|
前端开发
记忆面包:QoderWork CN 把厚书读薄
本案例基于阿里QoderWork CN桌面应用,通过安装“UI设计”技能,将学习笔记一键转化为含填空、选择、判断等题型的交互式复习卡片,支持HTML导出,大幅提升备考效率。
893 9
|
10天前
|
数据采集 存储 算法
视频 RAG 中分块策略:基于停顿、滑动窗口与基于 LLM 的方法
本文探讨视频RAG中的核心挑战——如何为无时间结构的视频转录文本设计有效分块策略。对比传统文本分块,提出基于停顿、重叠窗口、递归切分及LLM驱动的主题分块四层方案,实现细粒度检索与全局理解兼顾,提升视频内容检索准确性与上下文完整性。
156 13
视频 RAG 中分块策略:基于停顿、滑动窗口与基于 LLM 的方法
|
10天前
|
API
阿里云微服务引擎 MSE 及 API 网关 2026 年 5 月产品动态
阿里云微服务引擎 MSE 及 API 网关 2026 年 5 月产品动态。
186 20
|
10天前
|
机器学习/深度学习 数据采集 人工智能
田间杂草检测数据集分享(适用于YOLO系列深度学习分类检测任务)
本数据集含4000张真实农田图像(小麦/玉米/水稻田),YOLO格式标注杂草目标,覆盖多天气、光照与视角,适用于YOLO系列等目标检测模型训练,助力智能除草与精准农业研究。(239字)
292 16
|
10天前
|
人工智能 JavaScript 前端开发
Open Design:让你的 Coding Agent 变身设计引擎,本地优先的开源 Claude Design 替代品
Open Design 是开源本地化设计智能体,让 Claude/Cursor 等 Coding Agent 直接生成品牌一致的原型、MP4动效、PPTX演示稿与视觉资产。100+技能×150套DESIGN.md设计系统×261插件×21 Agent全适配,数据不出本机。
|
10天前
|
人工智能 缓存 弹性计算
阿里云服务器2核4G5M199元解析:独享型u1实例,性能、适用场景、购买和续费规则介绍
阿里云通用算力型u1实例(ecs.u1-c1m2.large)2核4G、5M带宽、80G ESSD Entry云盘,活动特惠价仅199元/年(官网价3498.36元),企业新老用户同享,续费同价至2027年3月31日,每人限购1台。该实例采用独享型架构,搭载Intel至强可扩展处理器,内网带宽1Gbit/s、收发包30万PPS、云盘IOPS 1万,性能稳定,适合企业官网、中小Web应用、轻量数据库及开发测试等场景。
|
10天前
|
安全 JavaScript 前端开发
《ZAKU渗透论:卓伊凡的2026渗透工程》第四章:Web攻击原理(下)——XSS、CSRF、文件上传漏洞
本章详解XSS、CSRF与文件上传三大Web漏洞:XSS通过注入恶意脚本窃取Cookie;CSRF伪造已登录用户请求执行非自愿操作;文件上传漏洞则因校验缺失致服务器被控。三者共性——过度信任用户输入。(239字)
308 10