redhat5.4 安装mysql_RedHat企业版5.4下Mysql5.1集群配置

一、实验介绍

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

cfc24852ee945e9d5471c5bda87a17b7.png

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

087c178e1583c30cd68c072f9c1fc542.png

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

8337261044d1d6d5c8e02728b38130cc.png

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

ndbcluster

ndb-connectstring=172.16.10.7

9016fc13471ffc95b0a89378170c050d.png

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

243ad662ade4335c8c2528eb51f7f110.gif

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

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

如图:

c3305c183fff0fe44b91e7fac7f0f671.png

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

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

bbd42d7178831acc16efb8bb6337510e.png

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

6066d99d70a8f1c5799b8f0b4c26ec86.png

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

如图所示:

f8483c0109f296f98c6b281b82c20e2f.gif

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

5b6c323441944ad9f1dd11610ade574a.png

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

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

如图:

3236c5c35cc7cf9d7eaa54da188dd56d.png

三、启动mysql集群服务

【注】

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

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

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

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

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

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

如图:

5f9ce71278a56914c2153bd18a155010.png

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

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

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

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

四、检查工作状态

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

c381acd9eafba353c3b5f60989c777b4.png

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

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

3d9415abb31a27f8cc6639cec8919596.png

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

82e39f868e0579ffd89d3bee39f16297.png

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

五、破坏性测试

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

fd19fdc59be2dbb44f1a5fe70c0ccc32.png

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

95a3f78a769d8478cab94fe8fc9a7bcc.png

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

45d01f197c70a47c08d9b6e70e479c34.png

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值