windows 环境下搭建mysql cluster 集群详细步骤

1、环境准备

下载mysql集群版本,我这里下载的是mysql-cluster-8.0.39-winx64

https://dev.mysql.com/downloads/cluster/

2、创建配置文件

mysql集群版本下载以后解压后目录如下,创建配置文件 config.ini(集群配置文件,my.ini mysql配置文件)

192.168.0.84 配置文件

config.ini

(192.168.0.84 主服务器 下面是两台服务器 192.168.0.84 192.168.0.54)

复制代码
[ndb_mgmd]
NodeId=1
HostName=192.168.0.84
DataDir=F:/mysql-cluster-8.0.39-winx64/cluster-logs

[ndbd default]
NoOfReplicas=2
DataDir=F:/mysql-cluster-8.0.39-winx64/data
DataMemory=80M
IndexMemory=18M

[ndbd]
NodeId=2
HostName=192.168.0.84

[ndbd]
NodeId=3
HostName=192.168.0.54

[mysqld]
NodeId=4
HostName=192.168.0.84

[mysqld]
NodeId=5
HostName=192.168.0.54

my.ini(192.168.0.84 主服务器)

复制代码
[mysql]
default-character-set=utf8

[mysqld]
port=3307
default_authentication_plugin=mysql_native_password
basedir=F:/mysql-cluster-8.0.39-winx64/
datadir=F:/mysql-cluster-8.0.39-winx64/data/
character-set-server=utf8
default-storage-engine=ndbcluster
collation-server=utf8_unicode_ci
init_connect='SET NAMES utf8'
innodb_buffer_pool_size=2G
innodb_lock_wait_timeout=30
innodb_log_buffer_size=8M
innodb_log_file_size=16M
join_buffer_size=200M
key_buffer_size=400M
log-error="F:/mysql-cluster-8.0.39-winx64/log-error.log"
log_error_verbosity=1
max_allowed_packet=50000M
max_connections=1000
max_heap_table_size=6400M
myisam_max_sort_file_size=64G
myisam_sort_buffer_size=32M
read_buffer_size=4kb
read_rnd_buffer_size=4000M
server_id=1
skip-external-locking=on
sort_buffer_size=256kb
table_open_cache=256
thread_cache_size=16
tmp_table_size=64M
wait_timeout=1800
interactive_timeout=86400
sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
group_concat_max_len=1024000
ngram_token_size=2
innodb_ft_max_token_size=1
ft_min_word_len=1
[client]
port=3307
default-character-set=utf8

192.168.0.54配置文件

config.ini

复制代码
[ndbd]
NodeId=3
HostName=192.168.0.54
DataDir=F:/mysql-cluster-8.0.39-winx64/data

[ndbd default]
NoOfReplicas=2
DataDir=F:/mysql-cluster-8.0.39-winx64/data
DataMemory=80M
IndexMemory=18M

[ndb_mgmd]
# 仅在管理节点上配置
# NodeId=1
# HostName=192.168.0.84
# DataDir=F:/mysql-cluster-8.0.39-winx64/cluster-logs

[mysqld]
# 在数据节点上不需要此部分,SQL 节点需要配置

my.ini

复制代码
[mysql]
default-character-set=utf8

[mysqld]
port=3307
default_authentication_plugin=mysql_native_password
basedir=F:/mysql-cluster-8.0.39-winx64/
datadir=F:/mysql-cluster-8.0.39-winx64/data/
character-set-server=utf8
default-storage-engine=ndbcluster
collation-server=utf8_unicode_ci
init_connect='SET NAMES utf8'
innodb_buffer_pool_size=16G
innodb_lock_wait_timeout=30
innodb_log_buffer_size=8M
innodb_log_file_size=16M
join_buffer_size=200M
key_buffer_size=400M
log-error="F:/mysql-cluster-8.0.39-winx64/data"
log_error_verbosity=1
max_allowed_packet=50000M
max_connections=1000
max_heap_table_size=6400M
myisam_max_sort_file_size=64G
myisam_sort_buffer_size=32M
read_buffer_size=4kb
read_rnd_buffer_size=4000M
server_id=1
skip-external-locking=on
sort_buffer_size=256kb
table_open_cache=256
thread_cache_size=16
tmp_table_size=64M
wait_timeout=1800
interactive_timeout=86400
sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
group_concat_max_len=1024000
ngram_token_size=2
innodb_ft_max_token_size=1
ft_min_word_len=1
ndbcluster
ndb-connectstring=192.168.0.84
[client]
port=3307
default-character-set=utf8

3、初始化数据库(用管理员权限执行)

初始化192.168.0.84数据库

进入bin目录,执行 mysqld --initialize --console

初始化192.168.0.54数据库

进入bin目录,执行 mysqld --initialize --console

4、启动集群数据库

启动192.168.0.84数据库

(1)启动 ndb_mgmd 数据库管理节点

复制代码
ndb_mgmd.exe --config-file=F:\mysql-cluster-8.0.39-winx64\config.ini --configdir=F:\mysql-cluster-8.0.39-winx64

(2)启动数据节点 ndbd.exe

复制代码
ndbd.exe

(3) 启动数据库

复制代码
mysqld.exe --ndbcluster --ndb-connectstring=192.168.0.84 --console

启动192.168.0.54数据库

(1)启动数据节点 ndbd.exe 需要指定集群的主节点

复制代码
ndbd.exe --ndb-connectstring=192.168.0.84

(2)启动数据库

复制代码
mysqld.exe --ndbcluster --ndb-connectstring=192.168.0.84 --console

5、集群环境搭建完成

使用数据库连接工具,测试。

注意:创建表时必须指定 ENGINE=ndbcluster,才能确保表在 MySQL Cluster 环境中创建并利用集群的特性。这是因为 MySQL Cluster 是一个分布式数据库,使用了专门的存储引擎 NDB (Network Database),它与传统的 InnoDB 或 MyISAM 存储引擎不同。

6、为什么需要指定 ENGINE=ndbcluster

(1)数据分布 : NDB 存储引擎支持将数据分布到多个数据节点,这样可以提高数据的可靠性和性能。

(2)高可用性 : NDB 存储引擎能够自动处理数据副本和故障转移,从而提高系统的可用性。

(3)一致性 : 在 MySQL Cluster 中,NDB 引擎保证了数据在所有数据节点上的一致性。

相关推荐
Elastic 中国社区官方博客3 小时前
在 Elasticsearch 中使用 Mistral Chat completions 进行上下文工程
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
编程爱好者熊浪4 小时前
两次连接池泄露的BUG
java·数据库
南宫乘风5 小时前
基于 Flask + APScheduler + MySQL 的自动报表系统设计
python·mysql·flask
TDengine (老段)6 小时前
TDengine 字符串函数 CHAR 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
qq7422349846 小时前
Python操作数据库之pyodbc
开发语言·数据库·python
姚远Oracle ACE7 小时前
Oracle 如何计算 AWR 报告中的 Sessions 数量
数据库·oracle
Dxy12393102167 小时前
MySQL的SUBSTRING函数详解与应用
数据库·mysql
码力引擎7 小时前
【零基础学MySQL】第十二章:DCL详解
数据库·mysql·1024程序员节
杨云龙UP7 小时前
【MySQL迁移】MySQL数据库迁移实战(利用mysqldump从Windows 5.7迁至Linux 8.0)
linux·运维·数据库·mysql·mssql
l1t7 小时前
利用DeepSeek辅助修改luadbi-duckdb读取DuckDB decimal数据类型
c语言·数据库·单元测试·lua·duckdb