Mysql cluster7.2.6 在Redhat6.5上的集群安装方法

一、环境要求

安装环境:Red Hat6.5 64位
软件名称(通用版本):mysql-cluster-gpl-7.2.6-linux2.6-x86_64.tar.gz(5.5.22-ndb-7.2.6-gpl-log )
下载地址:https://downloads.mysql.com/archives/cluster/
软件安装位置:/usr/local/mysql
数据存放位置:/var/mysql/data
日志存放位置:/var/mysql/logs


共需要5台服务器,服务器分配如下: 
管理节点:192.168.1.117

数据节点1:192.168.1.228
数据节点2:192.168.1.229
sql节点1:192.168.1.230
sql节点2:192.168.1.232
设备的连接方式如下图所示:

注意:目前这种设计存在的问题是管理节点是单点的,117挂掉后整个集群就会瘫痪,先不管这个问题,首先把这个简单的MySQL集群先搭建起来。

二、环境搭建
1.管理节点
1)安装管理节点(192.168.1.117

[root@service1 ~]# groupadd mysql
[root@service1 ~]# useradd mysql -g mysql
[root@service1 ~]# cd /usr/local
[root@service1 local]# tar -zxv -f mysql-cluster-gpl-7.2.6-linux2.6-x86_64.tar.gz
[root@service1 local]# mv mysql-cluster-gpl-7.2.6-linux2.6-x86_64 mysql
[root@service1 local]# chown -R mysql:mysql mysql
[root@service1 local]# cd mysql
[root@service1 mysql]# scripts/mysql_install_db --user=mysql
[root@service1 mysql]# mkdir /var/lib/mysql-cluster
[root@service1 mysql]# cd /var/lib/mysql-cluster

[root@service1 mysql]# mkdir -p /var/mysql/logs

[root@service1 mysql]# mkdir -p /var/mysql/data

chown -R mysql:mysql /var/mysql     //切忌权限问题
[root@localhost mysql-cluster]# vi /var/lib/mysql-cluster/config.ini

 我的理解是这个参数是控制数据份数的,如果是2 表有两份数据,如果是1表示只有一份数据. mycluster 中没有参数设计节点组数. 节点组数=节点数/NoOfReplicas.
  所以你如果总共有两个数据节点,如果NoOfReplicas设为2, 那么意味着只有一个节点组. 如果NoOfReplicas=1,那么就有两个节点组,即有一份备份.
  在这种情况下,当NoOfReplicas=2时, 你可以试验一下如果一个data node 停掉了,cluster 可以照常工作; 如果NoOfReplicas=1, 一个data node 停掉了,cluster 就会自动停掉.

config.ini 中添加以下内容:

[NDBD DEFAULT]
NoOfReplicas=2
[TCP DEFAULT]
portnumber=3306
[NDB_MGMD]
#设置管理节点服务器
HostName=192.168.1.117
DataDir=/var/mysql/data
[NDBD]
#设置存储节点服务器(NDB节点)
HostName=192.168.1.228
DataDir=/var/mysql/data
[NDBD]
#第二个NDB节点
HostName=192.168.1.229
DataDir=/var/mysql/data
[MYSQLD]
#设置SQL节点服务器
HostName=192.168.1.230
[MYSQLD]
#第二个SQL节点
HostName=192.168.1.232

(2)管理节点启动 
[root@service1 mysql]#/usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini --initial

-initial 首次加载/data/program/mysqlCluster/etc/config.ini文件有改变,其它时候不要加,除非是在备份、恢复或配置变化后重启时,其他时候不要加,不然数据就清空

#如果有改动要加上

每次修改config.ini文件,重启ndb_mgmd时,需要删除mysql-cluster文件下的ndb_1_config.bin.1文件

rm -rf /usr/local/mysql/mysql-cluster/ndb_1_config.bin.1

[root@service1 mysql]# /usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini

MySQL Cluster Management Server mysql-5.5.22 ndb-7.2.6

2018-05-15 16:46:48 [MgmtSrvr] INFO     -- The default config directory '/usr/local/mysql/mysql-cluster' does not exist. Trying to create it...

2018-05-15 16:46:48 [MgmtSrvr] INFO     -- Sucessfully created config directory

2018-05-15 16:46:48 [MgmtSrvr] WARNING  -- at line 4: [TCP] portnumber is deprecated

这个警告提示可以不必理会,不影响使用;

查看3306端口:netstat -anp |grep 3306
[root@service1 mysql]# netstat -lntpu   看到tcp 0 0 0.0.0.0:1186开放说明启动正常 

3)管理节点检验 
执行以下操作:

[root@service1 bin]# ndb_mgm

-bash: ndb_mgm: command not found

[root@service1 bin]# /usr/local/mysql/bin/ndb_mgm

-- NDB Cluster -- Management Client --

ndb_mgm>
-- NDB Cluster -- Management Client --
ndb_mgm> show
Connected to Management Server at: localhost:1186
Cluster Configuration
---------------------
[ndbd(NDB)]     2 node(s)
id=2 (not connected, accepting connect from 192.168.1.228)
id=3 (not connected, accepting connect from 192.168.1.229)

[ndb_mgmd(MGM)] 1 node(s)
id=1    @192.168.1.117  (mysql-5.5.22 ndb-7.2.6)

[mysqld(API)]   2 node(s)
id=4 (not connected, accepting connect from 192.168.1.230)
id=5 (not connected, accepting connect from   192.168.1.232)
4)管理节点关闭 
[root@service1 ~]# /usr/local/mysql/bin/ndb_mgm -e shutdown

Connected to Management Server at: localhost:1186

3 NDB Cluster node(s) have shutdown.

Disconnecting to allow management server to shutdown.

关闭时只需要关闭管理节点,后面的数据节点会同时被关闭

2.数据节点 

1)数据节点安装
数据节点1: 192.168.1.228
数据节点2: 192.168.1.229

[root@service2 ~]# groupadd mysql
[root@service2 ~]# useradd mysql -g mysql
[root@service2 ~]# cd /usr/local
[root@service2 local]# tar -zxv -f mysql-cluster-gpl-7.2.6-linux2.6-x86_64.tar.gz
[root@service2 local]# mv mysql-cluster-gpl-7.2.6-linux2.6-x86_64 mysql
[root@service2 local]# chown -R mysql:mysql mysql
[root@service2 local]# cd mysql
[root@service2 mysql]# scripts/mysql_install_db --user=mysql
[root@service2 mysql]# cp support-files/my-medium.cnf /etc/my.cnf
[root@service2 mysql]# cp support-files/mysql.server /etc/init.d/mysqld

数据节点配置 
对数据节点进行配置,执行以下操作:

[root@service2 ~]# mkdir -p /var/mysql/logs

[root@service2 ~]# mkdir -p /var/mysql/data

chown -R mysql:mysql /var/mysql
[root@service2 ~]# vi /etc/my.cnf
向文件追加以下内容:

[MYSQLD]
ndbcluster
ndb-connectstring=192.168.1.117
[MYSQL_CLUSTER]
ndb-connectstring=192.168.1.117
[NDB_MGM]
connect-string=192.168.1.117
2)数据节点启动 
启动此处时,管理节点服务器防火墙必须开启1186,3306端口。 
注意:只是在第一次启动或在备份/恢复或配置变化后重启ndbd时,才加–initial参数! 
第一次启动如下:

[root@service2 mysql]#/usr/local/mysql/bin/ndbd --initial
2013-01-30 13:43:53 [ndbd] INFO  -- Angel connected to '192.168.1.117:1186'
2013-01-30 13:43:53 [ndbd] INFO  -- Angel allocated nodeid: 2正常启动方式:

[root@localhost mysql]# /usr/local/mysql/bin/ndbd

3)数据节点关闭(关闭管理,会关闭数据节点)

3. SQL节点

1)SQL节点安装
SQL节点和存储节点(NDB节点)安装相同,都执行以下操作; 
sql节点1: 192.168.1.230
sql节点2:192.168.1.232

[root@service4 ~]# groupadd mysql
[root@service4 ~]# useradd mysql -g mysql
[root@service4 ~]# cd /usr/local
[root@service4 local]# tar -zxv -f mysql-cluster-gpl-7.2.6-linux2.6-x86_64.tar.gz
[root@service4 local]# mv mysql-cluster-gpl-7.2.6-linux2.6-x86_64 mysql
[root@service4 local]# chown -R mysql:mysql mysql
[root@service4 local]# cd mysql
[root@service4 mysql]# scripts/mysql_install_db --user=mysql
[root@service4 mysql]# cp support-files/my-medium.cnf /etc/my.cnf
[root@service4 mysql]# cp support-files/mysql.server /etc/init.d/mysqld

SQL节点配置 
执行以下操作:

[root@service4 mysql]# mkdir -p /var/mysql/data  //创建存储数据的文件夹
[root@service4 mysql]# mkdir -p /var/mysql/logs  //创建存储日志的文件夹

chown -R mysql:mysql /var/mysql    //权限配置
[root@service4 mysql]# vi /usr/local/mysql/my.cnf  //修改配置文件追加以下内容:

[MYSQLD]
ndbcluster
ndb-connectstring=192.168.1.117
[MYSQL_CLUSTER]
ndb-connectstring=192.168.1.117
[NDB_MGM]
connect-string=192.168.1.117

2)SQL节点启动 
执行以下操作:

[root@service4 mysql]# service mysqld start
Starting MySQL.. SUCCESS!

(3)SQL节点关闭 
最直接的方式:

service mysqld stop

[root@service4 mysql]# /usr/local/mysql/bin/mysqladmin -u root shutdown

或者

[root@service4 /]# /etc/rc.d/init.d/mysqld stop =  [root@service4 mysql]# /etc/init.d/mysqld stop
Shutting down MySQL.. SUCCESS!功能测试 

4)管理节点查看所有节点状态
在管理节点(192.168.1.117)上查看服务状态

[root@service1 ~]# /usr/local/mysql/bin/ndb_mgm

-- NDB Cluster -- Management Client --

ndb_mgm> show

Connected to Management Server at: localhost:1186

Cluster Configuration

---------------------

[ndbd(NDB)]2 node(s)

id=32@192.168.1.228  (mysql-5.5.22 ndb-7.2.6, Nodegroup: 0)

id=3@192.168.1.229  (mysql-5.5.22 ndb-7.2.6, Nodegroup: 0, Master)

[ndb_mgmd(MGM)]1 node(s)

id=1@192.168.1.117  (mysql-5.5.22 ndb-7.2.6)

[mysqld(API)]4 node(s)

id=4@192.168.1.230  (mysql-5.5.22 ndb-7.2.6)

id=5@192.168.1.232  (mysql-5.5.22 ndb-7.2.6)

id=6 (not connected, accepting connect from any host)

id=7 (not connected, accepting connect from any host)

 

可以看到这里的数据节点、管理节点、sql节点都是正常的。 
注意:

1.在建表的时候一定要用ENGINE=NDB或ENGINE=NDBCLUSTER指定使用NDB集群存储引擎,或用ALTER TABLE选项更改表的存储引擎。 
2.NDB表必须有一个主键,因此创建表的时候必须定义主键,否则NDB存储引擎将自动生成隐含的主键。 
3.Sql节点的用户权限表仍然采用MYISAM存储引擎保存的,所以在一个Sql节点创建的MySql用户只能访问这个节点,如果要用同样的用户访问别的Sql节点,需要在对应的Sql节点追加用户。虽然在MySql Cluster7.2版本开始提供了”用户权限共享”。 
三、数据同步性测试 
在一个数据节点上进行相关数据库的创建,然后到另外一个数据节点上看看数据是否同步。

1步: 
SQL节点1(192.168.1.230)上增加数据:

[root@localhost mysql]# /etc/rc.d/init.d/mysqld status     //检验mysql是否运行
[root@localhost mysql]# /etc/rc.d/init.d/mysqld start   //启动mysql
[root@localhost mysql]# /usr/local/mysql/bin/mysql -u root -p
Enter password:

密码为空
mysql> show databases;
mysql> create database testdb2;
mysql> use testdb2;
mysql> CREATE TABLE td_test2 (i INT) ENGINE=NDB;
//这里必须指定数据库表的引擎为NDBCLUSTER,与配置文件中的名称相同
mysql> INSERT INTO td_test2() VALUES (1);
mysql> INSERT INTO td_test2() VALUES (152);
mysql> SELECT * FROM td_test2;

2步: 
进入到SQL节点2(192.168.1.232)上查看数据

mysql> use testdb2;
Database changed
mysql> SELECT * FROM td_test2;
+------+
| i |
+------+
|  126 |
| 1 |
+------+
2 rows in set (0.01 sec)

查看表的引擎是不是NDB:

>show create table td_test2;

3步: 
反向测试,SQL节点2(192.168.15.233)上增加数据:

mysql> create database bb;
mysql> use bb;
mysql> CREATE TABLE td_test3 (i INT) ENGINE=NDB;
mysql> INSERT INTO td_test3 () VALUES (98);
mysql> SELECT * FROM td_test3;

SQL节点1(192.168.1.230)上查看数据:

mysql> use bb;
Database changed
mysql> SELECT * FROM td_test3;

+------+

| i    |

+------+

|   98 |

+------+

1 row in set (0.02 sec)

 

四、关闭集群和重启

启动mysql集群。启动顺序为:管理节点→数据节点→SQL节点。

关闭时只需要关闭管理节点,后面的数据节点会同时被关闭,SQL节点单独关闭

管理节点:[root@service1 ~]# /usr/local/mysql/bin/ndb_mgm -e shutdown

SQL节点:service mysqld stop
再次启动数据节点时不要加”–initial”参数,否则会丢失数据。

 

 

你可能感兴趣的:(Mysql)