一、实验介绍
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/目录下,并解压之。如下图:
2、将解压后的软件包重命名为mysql,然后创建mysql用户和组,如图:
3、执行scripts/mysql_install_db --user=mysql命令创建mysql数据,如图:
4、将/usr/local/mysql/support-files/my-medium.cnf文件复制到 /etc/my.cnf下,修改/etc/my.cnf配置文件,在第38行处添加两行,如图:
ndbcluster
ndb-connectstring=172.16.10.7
在文件尾部添加如下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文件,如图:
5、为方便实验进行,创建一些快捷命令,当然也可不创建。
将mysql.server文件复制到init.d文件下,增加可执行权限,使其为开机自启动,并创建ndbd数据节点链接文件,然后在/etc/rc.local 文件中最后新增一行ndbd,
如图:
linuxtro1的配置与linuxtro2配置完全相同,请参照之。
6、接下来,就是配置管理节点linuxtro3了。前面步骤大致相同,解压缩,文件重命名为mysql,创建mysql用户和组,并修改文件权限。将/usr/local/mysql/support-files/my-medium.cnf文件复制到/etc/my.cnf中。修改my.cnf文件,在38行添加2行,在文件尾部添加6行,修改完毕后,保存退出。如图:
7、创建/var/lib/mysql-cluster文件夹,并在该目录下创建config.ini文件
#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]
如图所示:
8、接下来需要设置一些快捷命令,将mysql.server文件复制到init.d文件下,增加可执行权限,使其为开机自启动,并创建ndb_mgm和ndb_mgmd管理节点链接文件,
9、在/etc/rc.local文件末尾添加如下一行,并保存退出。
/usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini
如图:
三、启动mysql集群服务
【注】
1、mysql集群在启动过程中必须提前启动管理节点服务器,等管理节点启动成功后,再启动其它节点。
2、关闭整个集群的时候最好最后关闭管理节点
3、管理节点宕机后,剩下的某台主机再宕机后,这样就失去了集群的意义了。管理节点要保证7x24。
先启动作为管理节点的服务器(linuxtro3):
执行/usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini
命令,然后启动mysql数据库。
如图:
然后再启动作为普通节点的linuxtro1和linuxtro2,
执行/usr/local/mysql/bin/ndbd –initial 命令
注:只在第一次启动ndbd时使用--initial参数
然后启动mysql数据库,命令为:service mysqld start
四、检查工作状态
在linuxtro3上执行ndb_mgm命令,如显示如下信息则说明工作正常!如图:
接下来测试mysql,现在linuxtro1的test数据库上创建一张linuxtro表,来验证三台机器的mysql是否能够同步。如图:
此处mysql没有设置密码,在实际生产环境中建议设置数据库的root密码。
现在到linuxtro2上的数据库中查看数据是否已经同步,如图:
数据已经成功同步到linuxtro2数据库里面了,在linuxtro3数据库里面,同样可以看到同步过来的数据。
五、破坏性测试
接下来,真正的考验来了,假设linuxtro1服务器宕机了,数据库内数据丢失。为了模拟这种场景,在linuxtro1将ndbd进程杀掉,以达到破坏数据库集群的目的。如图:
现在切换到另外的数据库服务器上,使用SELECT进行查询,如图:
与此同时,在管理节点linuxtro3服务器上,可以使用show命令查看到被破坏的数据库服务器。如图:
测试完成后,只需要重新启动被破坏服务器的ndbd进程即可恢复数据库。