如何搭建MySQL集群

100次阅读
没有评论

共计 6542 个字符,预计需要花费 17 分钟才能阅读完成。

这篇文章给大家介绍如何搭建 MySQL 集群,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

概述

MySQL Cluster 是 MySQL 适合于分布式计算环境的高实用、可拓展、高性能、高冗余版本,其研发设计的初衷就是要满足许多行业里的最严酷应用要求,这些应用中经常要求数据库运行的可靠性要达到 99.999%。MySQL Cluster 允许在无共享的系统中部署“内存中”数据库集群,通过无共享体系结构,系统能够使用廉价的硬件,而且对软硬件无特殊要求。此外,由于每个组件有自己的内存和磁盘,不存在单点故障。

实际上,MySQL 集群是把一个叫做 NDB 的内存集群存储引擎集成与标准的 MySQL 服务器集成。它包含一组计算机,每个都跑一个或者多个进程,这可能包括一个 MySQL 服务器,一个数据节点,一个管理服务器和一个专有的一个数据访问程序。

MySQL Cluster 能够使用多种故障切换和负载平衡选项配置 NDB 存储引擎,但在 Cluster 级别上的存储引擎上做这个最简单。以下为 MySQL 集群结构关系图,

MySQL 从结构看,由 3 类节点 (计算机或进程) 组成,分别是:

管理节点: 用于给整个集群其他节点提供配置、管理、仲裁等功能。理论上通过一台服务器提供服务就可以了。

数据节点:MySQL Cluster 的核心,存储数据、日志,提供数据的各种管理服务。2 个以上 时就能实现集群的高可用保证,DB 节点增加时,集群的处理速度会变慢。

SQL 节点(API): 用于访问 MySQL Cluster 数据,提供对外应用服务。增加 API 节点会提高整个集群的并发访问速度和整体的吞吐量,该节点 可以部署在 Web 应用服务器上,也可以部署在专用的服务器上,也开以和 DB 部署在 同一台服务器上。

NDB 引擎

MySQL Cluster 使用了一个专用的基于内存的存储引擎 mdash; mdash;NDB 引擎,这样做的好处是速度快,没有磁盘 I / O 的瓶颈,但是由于是基于内存的,所以数据库的规模受系统总内存的限制,如果运行 NDB 的 MySQL 服务器一定要内存够大,比如 4G, 8G, 甚至 16G。NDB 引擎是分布式的,它可以配置在多台服务器上来实现数据的可靠性和扩展性,理论上 通过配置 2 台 NDB 的存储节点就能实现整个数据库集群的冗余性和解决单点故障问题。

缺陷

基于内存,数据库的规模受集群总内存的大小限制

基于内存,断电后数据可能会有数据丢失,这点还需要通过测试验证。

多个节点通过网络实现通讯和数据同步、查询等操作,因此整体性受网络速度影响,因此速度也比较慢

2.2 优点

多个节点之间可以分布在不同的地理位置,因此也是一个实现分布式数据库的方案。

扩展性很好,增加节点即可实现数据库集群的扩展。

冗余性很好,多个节点上都有完整的数据库数据,因此任何一个节点宕机都不会造成服务中断。

实现高可用性的成本比较低,不象传统的高可用方案一样需要共享的存储设备和专用的软件才能实现,NDB 只要有足够的内存就能实现。

本文将搭建一个最简化的 MySQL Cluster 系统,配置方法中的所有命令都是以 root 账户运行。这个 MySQL Cluster 包含一个管理结点、两个数据结点、两个 SQL 结点,这五个结点会分别安装在五个虚拟机上,虚拟机的名称和 IP 如下所示:

一、公共配置

请在三个虚拟机上分别配置此处的配置项。

1. 安装虚拟机

虚拟机操作系统安装 CentOS 6.4 的 x86_64 版本,使用 NAT 网络,并且还要安装 vmware-tools,具体安装方法此处不详述。

2. 拷贝 mysql cluster

下载以下版本的 MySQL-Cluster:

http://cdn.mysql.com/Downloads/MySQL-Cluster-7.3/mysql-cluster-gpl-7.3.4-linux-glibc2.5-x86_64.tar.gz

下载得到的压缩包拷贝至虚拟机的 /root/Downloads 目录,然后在 shell 中运行以下命令:

cd /root/Downloads tar -xvzf mysql-cluster-gpl-7.3.4-linux-glibc2.5-x86_64.tar.gz mv mysql-cluster-gpl-7.3.4-linux-glibc2.5-x86_64 /usr/local/mysql

3. 关闭安全策略

关闭 iptables 防火墙(或者打开防火墙的 1186、3306 端口),在 Shell 中运行以下命令:

chkconfig --level 35 iptables off

关闭 SELinux,在 Shell 中运行以下命令:

gedit /etc/selinux/config

将 config 文件中的 SELINUX 项改为 disabled,修改后的 config 文件的内容如下:

# This file controls the state of SELinux on the system. # SELINUX= can take one of these three values: # enforcing - SELinux security policy is enforced. # permissive - SELinux prints warnings instead of enforcing. # disabled - No SELinux policy is loaded. SELINUX=disabled # SELINUXTYPE= can take one of these two values: # targeted - Targeted processes are protected, # mls - Multi Level Security protection. SELINUXTYPE=targeted

*** 重启系统

二、配置管理结点(192.168.124.141)

1. 配置 config.ini 配置文件

在 shell 中运行以下命令:

mkdir /var/lib/mysql-cluster cd /var/lib/mysql-cluster gedit config.ini

配置文件 config.ini 内容如下:

[ndbd default] NoOfReplicas=2 DataMemory=80M IndexMemory=18M [ndb_mgmd] NodeId=1 hostname=192.168.124.141 datadir=/var/lib/mysql-cluster [ndbd] NodeId=2 hostname=192.168.124.142 datadir=/usr/local/mysql/data [ndbd] NodeId=3 hostname=192.168.124.143 datadir=/usr/local/mysql/data [mysqld] NodeId=4 hostname=192.168.124.144 [mysqld] NodeId=5 hostname=192.168.124.145

2. 安装管理结点

安装管理节点,不需要 mysqld 二进制文件,只需要 MySQL Cluster 服务端程序 (ndb_mgmd) 和监听客户端程序(ndb_mgm)。在 shell 中运行以下命令:

cp /usr/local/mysql/bin/ndb_mgm* /usr/local/bin cd /usr/local/bin chmod +x ndb_mgm*

三、配置数据结点(192.168.124.142、192.168.124.143)

1. 添加 mysql 组和用户

在 shell 中运行以下命令:

groupadd mysql useradd -g mysql mysql

2. 配置 my.cnf 配置文件

在 shell 中运行以下命令:

gedit /etc/my.cnf

配置文件 my.cnf 的内容如下:

[mysqld] basedir=/usr/local/mysql datadir=/usr/local/mysql/data socket=/usr/local/mysql/sock/mysql.sock user=mysql # Disabling symbolic-links is recommended to prevent assorted security risks symbolic-links=0 [mysqld_safe] log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid [mysql_cluster] ndb-connectstring=192.168.124.141

3. 创建系统数据库

在 shell 中运行以下命令:

cd /usr/local/mysql mkdir sock scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

4. 设置数据目录

在 shell 中运行以下命令:

chown -R root . chown -R mysql.mysql /usr/local/mysql/data chown -R mysql.mysql /usr/local/mysql/sock chgrp -R mysql .

5. 配置 MySQL 服务

在 shell 中运行以下命令:

cp support-files/mysql.server /etc/rc.d/init.d/ chmod +x /etc/rc.d/init.d/mysql.server chkconfig --add mysql.server

四、配置 SQL 结点(192.168.124.144、192.168.124.145)

1. 添加 mysql 组和用户

在 shell 中运行以下命令:

groupadd mysql useradd -g mysql mysql

2. 配置 my.cnf 配置文件

在 shell 中运行以下命令:

gedit /etc/my.cnf

配置文件 my.cnf 的内容如下:

[client] socket=/usr/local/mysql/sock/mysql.sock [mysqld] ndbcluster datadir=/usr/local/mysql/data socket=/usr/local/mysql/sock/mysql.sock ndb-connectstring=192.168.124.141 [mysql_cluster] ndb-connectstring=192.168.124.141

3. 创建系统数据库

在 shell 中运行以下命令:

cd /usr/local/mysql mkdir sock scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

4. 设置数据目录

在 shell 中运行以下命令:

chown -R root . chown -R mysql.mysql /usr/local/mysql/data chown -R mysql.mysql /usr/local/mysql/sock chgrp -R mysql .

5. 配置 MySQL 服务

在 shell 中运行以下命令:

cp support-files/mysql.server /etc/rc.d/init.d/ chmod +x /etc/rc.d/init.d/mysql.server chkconfig --add mysql.server

五、Cluster 环境启动

注意启动顺序:首先是管理节点,然后是数据节点,*** 是 SQL 节点。

1. 启动管理结点

在 shell 中运行以下命令:

ndb_mgmd -f /var/lib/mysql-cluster/config.ini

还可以使用 ndb_mgm 来监听客户端,如下:

ndb_mgm

2. 启动数据结点

*** 启动,则需要添加 –initial 参数,以便进行 NDB 节点的初始化工作。在以后的启动过程中,则是不能添加该参数的,否则 ndbd 程序会清除在之前建立的所有用于恢复的数据文件和日志文件。

/usr/local/mysql/bin/ndbd --initial

如果不是 *** 启动,则执行下面的命令。

/usr/local/mysql/bin/ndbd

3. 启动 SQL 结点

若 MySQL 服务没有运行,则在 shell 中运行以下命令:

/usr/local/mysql/bin/mysqld_safe --user=mysql 

4. 启动测试

查看管理节点,启动成功

六、集群测试

1. 测试一

现在我们在其中一个 SQL 结点上进行相关数据库的创建, 然后到另外一个 SQL 结点上看看数据是否同步。

在 SQL 结点 1(192.168.124.144)上执行:

shell  /usr/local/mysql/bin/mysql -u root -p mysql show databases; mysql create database aa; mysql use aa; mysql CREATE TABLE ctest2 (i INT) ENGINE=NDB; // 这里必须指定数据库表的引擎为 NDB, 否则同步失败  mysql  INSERT INTO ctest2 () VALUES (1); mysql  SELECT * FROM ctest2;

然后在 SQL 结点 2 上看数据是否同步过来了

经过测试,在非 master 上创建数据,可以同步到 master 上

查看表的引擎是不是 NDB,show create table 表名;

2. 测试二

关闭一个数据节点,在另外一个节点写输入,开启关闭的节点,看数据是否同步过来。

首先把数据结点 1 重启,然后在结点 2 上添加数据

在 SQL 结点 2(192.168.124.145)上操作如下:

mysql  create database bb; mysql  use bb; mysql  CREATE TABLE ctest3 (i INT) ENGINE=NDB; mysql  use aa; mysql  INSERT INTO ctest2 () VALUES (3333); mysql  SELECT * FROM ctest2;

等数据结点 1 启动完毕,启动数据结点 1 的服务

#/usr/local/mysql/bin/ndbd --initial#service mysqld start

然后登录进去查看数据

# /usr/local/mysql/bin/mysql -u root  ndash;p

可以看到数据已经同步过来了,说明数据可以双向同步了。

七、关闭集群

1. 关闭管理节点和数据节点,只需要在管理节点 (ClusterMgm–134) 里执行:

shell  /usr/local/mysql/bin/ndb_mgm -e shutdown

显示

Connected to Management Server at: localhost:1186 2 NDB Cluster node(s) have shutdown. Disconnecting to allow management server to shutdown.

2. 然后关闭 Sql 节点(135,136),分别在 2 个节点里运行:

shell /etc/init.d/mysql.server stop

Shutting down MySQL… SUCCESS!

注意:要再次启动集群,就按照第五部分的启动步骤即可,不过这次启动数据节点的时候就不要加”-initial”参数了。

关于如何搭建 MySQL 集群就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计6542字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)