一、实验介绍

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/目录下,并解压之。如下图:

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

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

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

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

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

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

ndbcluster

ndb-connectstring=172.16.10.7

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

在文件尾部添加如下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文件,如图:

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

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

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

如图:

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

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

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

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

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

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

#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]

如图所示:

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

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

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

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

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

如图:

RedHat企业版5.4下Mysql5.1集群配置_数据库_11

三、启动mysql集群服务

【注】

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

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

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

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

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

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

如图:

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

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

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

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

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

四、检查工作状态

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

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

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

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

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

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

RedHat企业版5.4下Mysql5.1集群配置_数据库_15

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

五、破坏性测试

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

RedHat企业版5.4下Mysql5.1集群配置_数据库_16

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

RedHat企业版5.4下Mysql5.1集群配置_数据库_17

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

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

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