CentOS6.5安装mysql cluster7.3.7 搭建mysql数据库集群环境(双管理中心)

MySQL Cluster 是一种技术,该技术同意在无共享的系统中部署“内存中”数据库的 Cluster 。

通过无共享体系结构,系统可以使用便宜的硬件。并且对软硬件无特殊要求。

此外,因为每一个组件有自己的内存和磁盘。不存在单点故障。

MySQL Cluster 由一组计算机构成。每台计算机上均执行着多种进程,包含MySQLserver,NDB Cluster 的数据节点。管理server,以及(可能)专门的数据訪问程序。关于 Cluster 中这些组件的关系。

下文中没有特别指出的地方,都是两台server都须要运行的命令,而且因为是双管理中心配置,事实上两台机器出了一些标识id和ip的配置不同外,其它參数配置都是基本一样的

1、下载mysql-cluster 7.3.7
http://dev.mysql.com/downloads/cluster/

2、环境清理及安装
    1)清理CentOS6.5自带的mysql服务,当中第一个命令我不运行也能够。其它系统假设不能够。还是建议运行
# yum -y remove mysql
# rpm -qa | grep mysql*
# rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64
    2)环境准备  
创建目录(分例如以下3个类来创建相应的目录)
存储节点:# mkdir /var/lib/mysql/data 
管理节点:# mkdir /var/lib/mysql-cluster    SQL节点:可不用  目录授权
进程DIR:# mkdir /var/run/mysqld              
  
使用例如以下的命令来变更权限保证可写入:
# chmod -R 1777 /var/lib/mysql
# chmod -R 1777 /var/run/mysqld
# chmod -R 1777 /var/lib/mysql-cluster

    3)安装mysql-cluster
首先解压MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar
# tar xvf MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar
然后运行例如以下命令安装
# rpm -ivh MySQL-Cluster-server-gpl-7.3.4-1.el6.x86_64.rpm
# rpm -ivh MySQL-Cluster-client-gpl-7.3.4-1.el6.x86_64.rpm

特别注意,当安装完成server gpl包后。将出现例如以下提示信息,提醒我们整个cluster安装后的初次超级账户password存在/root/.mysql_secret这个文件其中。


---------------------------------------------------------------------------------------------------------------------
A RANDOM PASSWORD HAS BEEN SET FOR THE MySQL root USER !
 You will find that password in '/root/.mysql_secret'.
 You must change that password on your first connect,
 no other statement but 'SET PASSWORD' will be accepted.
 See the manual for the semantics of the 'password expired' flag.
 Also, the account for the anonymous user has been removed.
 In addition, you can run:
  /usr/bin/mysql_secure_installation
 which will also give you the option of removing the test database.
 This is strongly recommended for production servers.
 -----------------------------------------------------------


2、配置管理节点
1)运行例如以下命令:
cd /var/lib/mysql-cluster
# vi config.ini
2)配置config.ini文件,如附件
100.218的配置文件:
config.ini
配置信息:
[computer]
 Id=mgr-server-01
 HostName=192.168.100.218

 [mgm default]
 datadir=/var/lib/mysql-cluster

 [mgm]
 HostName=192.168.100.218
 NodeId=60

 [mgm]
 HostName=192.168.100.217
 NodeId=61

 [ndbd default]
 NoOfReplicas = 2
 DataMemory = 50M
 IndexMemory = 50M
 MaxNoOfTables = 1024
 MaxNoOfAttributes = 5000000
 MaxNoOfOrderedIndexes = 10000

 [ndbd]
 HostName=192.168.100.217
 DataDir=/var/lib/mysql
 NodeId=1

 [ndbd]
 HostName=192.168.100.218
 DataDir=/var/lib/mysql
 NodeId=2

 [mysqld]
 HostName=192.168.100.217
 NodeId=81

 [mysqld]
 HostName=192.168.100.218
 NodeId=82


100.217的配置文件:
config.ini
配置信息:
[computer]
 Id=mgr-server-02
 HostName=192.168.100.217

 [mgm default]
 datadir=/var/lib/mysql-cluster

 [mgm]
 HostName=192.168.100.218
 NodeId=60
 
 [mgm]
 HostName=192.168.100.217
 NodeId=61

 [ndbd default]
 NoOfReplicas = 2
 DataMemory = 50M
 IndexMemory = 50M
 MaxNoOfTables = 1024
 MaxNoOfAttributes = 5000000
 MaxNoOfOrderedIndexes = 10000

 [ndbd]
 HostName=192.168.100.217
 DataDir=/var/lib/mysql
 NodeId=1

 [ndbd]
 HostName=192.168.100.218
 DataDir=/var/lib/mysql
 NodeId=2

 [mysqld]
 HostName=192.168.100.217
 NodeId=81

 [mysqld]
 HostName=192.168.100.218
 NodeId=82


事实上两个文件区别不大。就在于computer配置中的名称和标识id

3、SQL节点和数据节点的配置
改动my.cnf文件。加入例如以下内容:
 [client]
 socket=/var/lib/mysql/mysql.sock
 [mysqld]
 max_connections=100
 datadir=/var/lib/mysql
 socket=/var/lib/mysql/mysql.sock
 ndbcluster
 ndb-connectstring=192.168.100.218,192.168.100.217
 [mysqld_safe]
 log-error=/var/log/mysqld.log
 #pid-file=/var/run/mysqld/mysqld.pid
 pid-file=/var/lib/mysql/mysqld.pid

 [mysql_cluster]
 ndb-connectstring=192.168.100.218,192.168.100.217


4、MySQL Cluster初次启动命令以及用户password更改调整:(请严格依照次序启动)
1)启动mysql-cluster
运行初次启动前请先确认 将两台机器的防火墙关闭(service iptables stop 或者 设定 防火墙port可通,两个port即通讯port1186、数据port3306 )
初次启动mgt console命令:ndb_mgmd -f /var/lib/mysql-cluster/config.ini  (初始化须要加--initial)
启动均衡节点命令:              ndbd --initial
启动数据节点命令:              mysqld_safe --defaults-file=/usr/my.cnf --explicit_defaults_for_timestamp &

my.cnf在有些系统中是在etc文件夹下
注意在启动过程中须要监測整个控制台输出,发现有错误信息须要及时解决,依据错误日志内容来解决。

---------------------------------------------------------------------------------------------------------
假设一起正常,使用例如以下命令将Management console开启:  ndb_mgm
运行# show
检查是否各个节点都已经全然启动。例如以下。每一个节点都已经连接,假设有节点没连接,会看到
ndb_mgm> show
Connected to Management Server at: 192.168.100.218:1186
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=1 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0)
id=2 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0, *)
[ndb_mgmd(MGM)] 1 node(s)
id=60 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)
id=61 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)
[mysqld(API)] 2 node(s)
id=81 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)
id=82 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)
假设有节点没连接。例如以下。id=81一行,表示没连接。检查问题故障点
ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=1 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0)
id=2 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0, *)
[ndb_mgmd(MGM)] 1 node(s)
id=60 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)
id=61 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)
[mysqld(API)] 2 node(s)
id=81 (not connected, accepting connect from 192.168.100.217)
id=82 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)


2)改动password
当mysqld 启动完成正常后(能够使用pgrep mysqld来获取进程ID),我们能够使用例如以下命令改动:
mysql -u root -p;
随机password(详细请參见/root/.mysql_secret文件获取),进入后使用例如以下指令改动password:
SET PASSWORD = PASSWORD('新password');
可是这个新password,必须是hash值,所以要使用例如以下方式获取password字符串的hash值
select password('111111')。
然而运行上面命令,会让你先设置password,郁闷,又绕回来了。那就去其它地方的mysql上运行下吧
111111的hash值是“*FD571203974BA9AFE270FE62151AE967ECA5E0AA”
SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE967ECA5E0AA');
好郁闷啊,设置完以后,登陆还必须使用密文,那好吧,就用密文进去,进去后使用例如以下命令,强制使用明文进行登陆
use mysql;
delete from user;
grant all on *.* to root@'%' identified by "111111" with grant option;
flush privileges;
quit;
然后,能够使用明文password登陆了

几台装有SQL数据节点的server皆须要运行一遍上述命令;

5、当上面步奏都操作完毕以后,測试cluster是否正常工作
1简单功能測试
在218上进入mysql后运行例如以下:
create database clustertest;
use clustertest; 
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER; 
注意:ENGINE=NDBCLUSTER; 引擎必须使用NDBCLUSTER才干够同步。否则不会进行同步
检查是否成功,在217上。进去mysql,查看是否自己主动创建了database和table,假设创建,则表示成功,假设失败,请检查环境配置
2)測试灾备情况下数据能否够同步(一台数据库停掉了,再启动的时候,是否会将遗失的数据自己主动补充)
停掉217上的mysql服务,在218上运行
insert into testtable values (1);
启动217的mysql服务。使用show确认217的数据库节点已经连接上了,运行例如以下语句
select * from testtable;
假设发现有数据。则表示功能完备
6、关闭Cluster:(须要严格依照次序运行)

关闭数据节点:# mysqld stop  (SQL节点能够用mysqladmin shutdown或别的方式关闭。)

在管理节点上运行:# ndb_mgm -e shutdown

将安全的关闭管理节点和数据节点。

关闭后使用例如以下的进程检測命令查看一下是否退出来了:

# pgrep mysqld

# ps aux | grep nbdb 

假设没有。找到相应的pid进行kill 操作就可以

kill -9 进程号

7、再次启动Cluster方案:
启动整个cluster的次序,注意,一些语句已经减去了初始化的内容:
ndb_mgmd -f /var/lib/mysql-cluster/config.ini
ndbd
mysqld_safe --defaults-file=/usr/my.cnf --explicit_defaults_for_timestamp &


备注:
1、mysql安装后,默认会自己主动启动的。每次启动cluster的时候。都须要先把mysql的服务关闭,太麻烦,于是能够运行例如以下命令(我出手有点狠):
chkconfig --level 123456 mysql off
2、防火墙问题,偷个懒,我懒得去一一开放port,干脆把防火墙直接关了(极不推荐的做法)
chkconfig --level 123456 iptables off

參考相关文档:
MySQL Cluster config.ini文件配置具体解释:

MySQL Cluster 备份与恢复 http://www.linuxidc.com/Linux/2013-06/85295.htm

MySQL Cluster安装配置 http://www.linuxidc.com/Linux/2013-07/87705.htm

MySQL Cluster 3台机器搭建集群环境 DOC http://www.linuxidc.com/Linux/2013-01/78249.htm

MySQL Cluster7.2在线添加数据节点存在重大弊端 http://www.linuxidc.com/Linux/2012-08/67605.htm

搭建MySQL-Cluster集群架构   http://www.linuxidc.com/Linux/2014-05/102218.htm


posted @ 2017-04-24 16:35  jzdwajue  阅读(286)  评论(0编辑  收藏  举报