一、环境要求
安装环境: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”参数,否则会丢失数据。