RedHat企业版5.4下Mysql5.1集群配置

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDSClaw,2核4GB
简介:

一、实验介绍

MYsql数据库集群由三部分组成,管理节点、存储节点和SQL节点。

管理节点是用来管理存储节点和SQL节点的,存储节点和SQL节点都要与管理节点通信;

存储节点是用来负载均衡存储数据,所用的存储引擎为NDB;

SQL节点是对外接口,用来与应用程序进行通信,应用程序只能访问它;

配置文件有两种:管理节点配置文件和普通节点配置文件,

config.ini是管理节点配置文件;my.cnf是数据节点和SQL节点配置文件。

config.ini文件中[ndb_mgmd]指明管理节点地址,[ndbd]指明数据节点地址,[mysqld]指明SQL节点地址。

一、 搭建实验环境

1、新建三台虚拟机,网卡选用VMnet3,机器IP分别是:

linuxtro1:172.16.10.5

linuxtro2:172.16.10.6

linuxtro3:172.16.10.7

2、Linux操作系统版本:RedHat企业版5.4

3、Mysql数据库版本:mysql-max-5.1.5-alpha-linux-i686-glibc23.tar

二、安装操作步骤

1、 将下载好的mysql软件包分别传到虚拟机中,由于linuxtro1和linuxtro2的配置是相同的,这里就以linuxtro2为例进行配置,将mysql包复制到/usr/local/目录下,并解压之。如下图:

clip_image002

2、将解压后的软件包重命名为mysql,然后创建mysql用户和组,如图:

clip_image004

3、执行scripts/mysql_install_db --user=mysql命令创建mysql数据,如图:

clip_image006

4、将/usr/local/mysql/support-files/my-medium.cnf文件复制到 /etc/my.cnf下,修改/etc/my.cnf配置文件,在第38行处添加两行,如图:

ndbcluster

ndb-connectstring=172.16.10.7

clip_image008

在文件尾部添加如下6行,

[ndbd]

connect-string=172.16.10.7

[ndb_mgm]

connect-string=172.16.10.7

[ndb_mgmd]

config-file=/var/lib/mysql-cluster

完成后,保存退出。并在/var/lib/下创建mysql-cluster文件,如图:

clip_image009

5、为方便实验进行,创建一些快捷命令,当然也可不创建。

将mysql.server文件复制到init.d文件下,增加可执行权限,使其为开机自启动,并创建ndbd数据节点链接文件,然后在/etc/rc.local 文件中最后新增一行ndbd,

如图:

clip_image011

linuxtro1的配置与linuxtro2配置完全相同,请参照之。

6、接下来,就是配置管理节点linuxtro3了。前面步骤大致相同,解压缩,文件重命名为mysql,创建mysql用户和组,并修改文件权限。将/usr/local/mysql/support-files/my-medium.cnf文件复制到/etc/my.cnf中。修改my.cnf文件,在38行添加2行,在文件尾部添加6行,修改完毕后,保存退出。如图:

clip_image013

7、创建/var/lib/mysql-cluster文件夹,并在该目录下创建config.ini文件

clip_image015

#touch config.ini

#vi config.ini

[NDBD DEFAULT]

NoOfReplicas= 2

DataDir= /var/lib/mysql-cluster

[NDB_MGMD]

Hostname= 172.16.10.7

DataDir= /var/lib/mysql-cluster

[NDBD]

HostName= 172.16.10.6

[NDBD]

HostName= 172.16.10.5

[MYSQLD]

[MYSQLD]

[MYSQLD]

如图所示:

clip_image016

8、接下来需要设置一些快捷命令,将mysql.server文件复制到init.d文件下,增加可执行权限,使其为开机自启动,并创建ndb_mgm和ndb_mgmd管理节点链接文件,

clip_image018

9、在/etc/rc.local文件末尾添加如下一行,并保存退出。

/usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini

如图:

clip_image020

三、启动mysql集群服务

【注】

1、mysql集群在启动过程中必须提前启动管理节点服务器,等管理节点启动成功后,再启动其它节点。

2、关闭整个集群的时候最好最后关闭管理节点

3、管理节点宕机后,剩下的某台主机再宕机后,这样就失去了集群的意义了。管理节点要保证7x24。

先启动作为管理节点的服务器(linuxtro3):

执行/usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini

命令,然后启动mysql数据库。

如图:

clip_image022

然后再启动作为普通节点的linuxtro1和linuxtro2,

执行/usr/local/mysql/bin/ndbd –initial 命令

注:只在第一次启动ndbd时使用--initial参数

然后启动mysql数据库,命令为:service mysqld start

四、检查工作状态

在linuxtro3上执行ndb_mgm命令,如显示如下信息则说明工作正常!如图:

clip_image024

接下来测试mysql,现在linuxtro1的test数据库上创建一张linuxtro表,来验证三台机器的mysql是否能够同步。如图:

此处mysql没有设置密码,在实际生产环境中建议设置数据库的root密码。

clip_image026

现在到linuxtro2上的数据库中查看数据是否已经同步,如图:

clip_image028

数据已经成功同步到linuxtro2数据库里面了,在linuxtro3数据库里面,同样可以看到同步过来的数据。

五、破坏性测试

接下来,真正的考验来了,假设linuxtro1服务器宕机了,数据库内数据丢失。为了模拟这种场景,在linuxtro1将ndbd进程杀掉,以达到破坏数据库集群的目的。如图:

clip_image030

现在切换到另外的数据库服务器上,使用SELECT进行查询,如图:

clip_image028[1]

与此同时,在管理节点linuxtro3服务器上,可以使用show命令查看到被破坏的数据库服务器。如图:

clip_image032

测试完成后,只需要重新启动被破坏服务器的ndbd进程即可恢复数据库。










本文转自 linuxtro 51CTO博客,原文链接:http://blog.51cto.com/linuxtro/408611,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
11月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
6月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
753 6
|
7月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
831 7
|
7月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
734 11
|
6月前
|
人工智能 弹性计算 安全
阿里云无影云电脑具体价格:个人版、企业版和免费云电脑配置介绍
阿里云无影云电脑2025年最新价格:企业版4核8G低至199元/年,支持办公与设计;个人版分黄金到黑金多款,月费14元起,适配云游戏与AI办公。含GPU高配机型,另享免费试用。
|
8月前
|
存储 新零售 安全
阿里云盘企业版收费标准、功能支持、存储配置及用户数全解析
阿里云盘企业版提供高性价比存储方案,500GB仅需169元/年,支持协同办公、权限管理、智能文件管理、多重安全防护及卓越性能,适用于多行业企业高效办公。
1315 0
|
12月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu 22.04上配置和安装MySQL
以上就是在Ubuntu 22.04上配置和安装MySQL的步骤。这个过程可能看起来有点复杂,但只要按照步骤一步步来,你会发现其实并不难。记住,任何时候都不要急于求成,耐心是解决问题的关键。
1397 31
|
11月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
614 11
|
12月前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。

推荐镜像

更多