首页 数据库 mysql教程 MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包 双管理中心)

MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包 双管理中心)

Jan 21, 2017 pm 12:01 PM

1、下载mysql-cluster 7.3.7

http://dev.mysql.com/downloads/cluster/


2、环境清理及安装

1)清理CentOS6.5自带的MySQL服务,其中第一个命令我不执行也可以,其他系统如果不可以,还是建议执行

1

2

3

# yum -y remove mysql 

# rpm -qa | grep mysql* 

# rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64

登录后复制

2)环境准备
创建文件夹(分如下3个类来创建对应的文件夹)

1

2

3

4

5

6

7

存储节点:# 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

1

2

3

4

5

首先解压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安装后的初次超级账户密码存在/root/.mysql_secret这个文件当中。

1

2

3

4

5

6

7

8

9

10

11

12

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

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. 

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

登录后复制

3、配置管理节点

1)执行如下命令:

1

2

# cd /var/lib/mysql-cluster 

# vi config.ini

登录后复制

2)配置config.ini文件,如附件
100.218的配置文件:

config.ini

配置信息:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

[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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

[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


4、SQL节点和数据节点的配置

修改my.cnf文件,添加如下内容:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

[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

登录后复制

5、MySQL Cluster初次启动命令以及用户密码更改调整:(请严格按照次序启动)

1)启动mysql-cluster
执行初次启动前请先确认 将两台机器的防火墙关闭(service iptables stop 或者 设定 防火墙端口可通,两个端口即通讯端口1186、数据端口3306 )
初次启动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
检查是否各个节点都已经完全启动,如下,每个节点都已经连接,如果有节点没连接,会看到

1

2

3

4

5

6

7

8

9

10

11

12

13

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一行,表示没连接,检查问题故障点

1

2

3

4

5

6

7

8

9

10

11

12

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)修改密码
当mysqld 启动完毕正常后(可以使用pgrep mysqld来获取进程ID),我们可以使用如下命令修改:
mysql -u root -p;
随机密码(具体请参见/root/.mysql_secret文件获取),进入后使用如下指令修改密码:
SET PASSWORD = PASSWORD('新密码');
但是这个新密码,必须是hash值,所以要使用如下方式获取密码字符串的hash值
select password('111111');
然而执行上面命令,会让你先设置密码,郁闷,又绕回来了,那就去其他地方的mysql上执行下吧
111111的hash值是“*FD571203974BA9AFE270FE62151AE967ECA5E0AA”
SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE967ECA5E0AA');
好郁闷啊,设置完以后,登陆还必须使用密文,那好吧,就用密文进去,进去后使用如下命令,强制使用明文进行登陆

1

2

3

4

5

use mysql; 

delete from user; 

grant all on *.* to root@'%' identified by "111111" with grant option; 

flush privileges; 

quit;

登录后复制

1

2

3

4

5

6

然后,可以使用明文密码登陆了

几台装有SQL数据节点的服务器皆需要执行一遍上述命令;

 

6、当上面步奏都操作完成以后,测试cluster是否正常工作

1)简单功能测试

在218上进入mysql后执行如下:

登录后复制

1

2

3

create database clustertest; 

use clustertest;  

CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;

登录后复制

注意:ENGINE=NDBCLUSTER; 引擎必须使用NDBCLUSTER才可以同步,否则不会进行同步
检查是否成功,在217上,进去mysql,查看是否自动创建了database和table,如果创建,则表示成功,如果失败,请检查环境配置
2)测试灾备情况下数据是否可以同步(一台数据库停掉了,再启动的时候,是否会将遗失的数据自动补充)
停掉217上的mysql服务,在218上执行

1

insert into testtable values (1);

登录后复制

启动217的mysql服务,使用show确认217的数据库节点已经连接上了,执行如下语句

1

select * from testtable;

登录后复制

如果发现有数据,则表示功能完备


7、关闭Cluster:(需要严格按照次序执行)

关闭数据节点:# mysqld stop (SQL节点可以用mysqladmin shutdown或别的方式关闭。)
在管理节点上执行:# ndb_mgm -e shutdown
将安全的关闭管理节点和数据节点。
关闭后使用如下的进程检测命令查看一下是否退出来了:

1

2

# pgrep mysqld 

# ps aux | grep nbdb

登录后复制

如果没有,找到对应的pid进行kill 操作即可
kill -9 进程号


8、再次启动Cluster方案:

启动整个cluster的次序,注意,一些语句已经减去了初始化的内容:

1

2

3

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的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):

1

chkconfig --level 123456 mysql off

登录后复制

2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了(极不推荐的做法)

1

chkconfig --level 123456 iptables off

登录后复制

参考相关文档:

MySQL Cluster config.ini文件配置详解:

    http://note.youdao.com/share/?id=376407a1136d2032afb6ef68aa39fba5&type=note

    http://note.youdao.com/share/?id=3906996cbe3298a22fbb5a2196d6cbed&type=note

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

以上就是 MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包 双管理中心)的内容,更多相关内容请关注PHP中文网(www.php.cn)!


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

两个点博物馆:邦格荒地地点指南
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

两个点博物馆:邦格荒地地点指南
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP 的大数据结构处理技巧 PHP 的大数据结构处理技巧 May 08, 2024 am 10:24 AM

PHP 的大数据结构处理技巧

如何优化 PHP 中的 MySQL 查询性能? 如何优化 PHP 中的 MySQL 查询性能? Jun 03, 2024 pm 08:11 PM

如何优化 PHP 中的 MySQL 查询性能?

如何在 PHP 中使用 MySQL 备份和还原? 如何在 PHP 中使用 MySQL 备份和还原? Jun 03, 2024 pm 12:19 PM

如何在 PHP 中使用 MySQL 备份和还原?

Java 枚举类型在数据库中的应用场景有哪些? Java 枚举类型在数据库中的应用场景有哪些? May 05, 2024 am 09:06 AM

Java 枚举类型在数据库中的应用场景有哪些?

如何使用 PHP 插入数据到 MySQL 表中? 如何使用 PHP 插入数据到 MySQL 表中? Jun 02, 2024 pm 02:26 PM

如何使用 PHP 插入数据到 MySQL 表中?

如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 Dec 09, 2024 am 11:42 AM

如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误

如何在 PHP 中使用 MySQL 存储过程? 如何在 PHP 中使用 MySQL 存储过程? Jun 02, 2024 pm 02:13 PM

如何在 PHP 中使用 MySQL 存储过程?

如何使用 PHP 创建 MySQL 表? 如何使用 PHP 创建 MySQL 表? Jun 04, 2024 pm 01:57 PM

如何使用 PHP 创建 MySQL 表?

See all articles