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安装后的初次超级账户密码存在/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文件[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

ExecuteOnComputer=mgr-server-01

PortNumber=1186

ArbitrationRank=2

[ndbd default]

NoOfReplicas=2

DataMemory=500M

IndexMemory=500M

[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

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

[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

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

1)启动mysql-cluster

执行初次启动前请先确认 将两台机器的防火墙关闭(service iptables stop 或者 设定 防火墙端口可通,两个端口即通讯端口1186、数据端口3306 )

初次启动mgt console命令:ndb_mgmd -f /var/lib/mysql-cluster/config.ini

启动均衡节点命令: ndbd --initial

启动数据节点命令: mysqld_safe --defaults-file=/etc/my.cnf --explicit_defaults_for_timestamp &

注意在启动过程中需要监测整个控制台输出,发现有错误信息需要及时解决,根据错误日志内容来解决。

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

如果一起正常,使用如下命令将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)

[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)

[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');

好郁闷啊,设置完以后,登陆还必须使用密文,那好吧,就用密文进去,进去后使用如下命令,强制使用明文进行登陆use mysql;

delete from user;

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

flush privileges;

quit;

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

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

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=/etc/my.cnf --explicit_defaults_for_timestamp &

备注:

1、mysql安装后,默认会自动启动的,每次启动cluster的时候,都需要先把mysql的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):

chkconfig --level 123456 mysql off

2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了

chkconfig --level 123456 mysql off

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

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

mysql cluster rpm包的作用_MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包)相关推荐

  1. MySQL分布式集群搭建详解

    搭建MySQL分布式集群,例如:利用MySQL cluster ,MySQL proxy,MySQL replication,drdb等等,有人会问MySQL集群意义是什么呢?为一个数据库减轻负担,说 ...

  2. linux 上elasticsearch集群搭建详解,手把手教学(tar下载包)

    1.安装jdk: 由于es是基于java的,所以先安装jdk: yum install java-1.8.0-openjdk* -y 此命令install结束后不用再去配置环境变量了,直接输入java ...

  3. mysql 存储引擎作用_MySQL常用存储引擎功能与用法详解

    MySQL存储引擎主要有两大类: 1. 事务安全表:InnoDB.BDB. 2. 非事务安全表:MyISAM.MEMORY.MERGE.EXAMPLE.NDB Cluster.ARCHIVE.CSV. ...

  4. mysql pxc搭建_MySQL PXC 高可用集群搭建

    一些名词介绍: WS:write set写数据集IST: Incremental State Transfer增量同步SST:State Snapshot Transfer全量同步 pxc环境所涉及的 ...

  5. mysql 两张表合并查询_mysql中的分区表和合并表详解(一个常见知识点)

    分区表是mysql5.1之后的新特性,合并表已经存在很长时间了.这篇文章主要介绍这两个概念以及他们基本的操作. 一.合并表 合并表说实话是一种将要被淘汰的技术,但是掌握了合并表的概念再去看分区表就比较 ...

  6. 【Redis】Redis高可用之Redis Cluster集群模式详解(Redis专栏启动)

  7. MySQL分布式集群搭建

    1 准备集群搭建环境 使用6台虚拟机来搭建MYSQL集群,相应的实验环境与对应的MYSQL节点之间的对应关系如下图所示: 节点名称 节点IP 节点内存 节点硬盘大小 节点CPU MYSQL节点角色 U ...

  8. mysql 集群_MySQL之PXC集群搭建

    一.PXC 介绍 1.1 PXC 简介 PXC 是一套 MySQL 高可用集群解决方案,与传统的基于主从复制模式的集群架构相比 PXC 最突出特点就是解决了诟病已久的数据复制延迟问题,基本上可以达到实 ...

  9. mysql集群 教程_mysql集群搭建教程-基础篇

    计算机一级考试系统要用集群,目标是把集群搭建起来,保证一个库dang了,不会影响程序的运行.于是在孟海滨师哥的带领下开始了我的第一次搭建mysql集群,首先看了一些关于集群的资料,然后根据步骤一步步的 ...

最新文章

  1. 为保障处理器平稳运行请“三知”cpu
  2. 3-2 -------WERTYU------题挺水的
  3. 编译原理实验报告_任意给定一个正规式 r (包括连接、或、闭包运算),根据 Thompson算法设计一个程序,生成与该正规式等价的 NFA N 。
  4. 探索云计算、大数据的特色化应用之路
  5. 不同维度的矩阵相乘的时间复杂度
  6. 自适应个人收款页HTML源码
  7. java按钮改变窗口大小_java – 当我们调整窗口大小时,Container中的元素如何调整?...
  8. java 扇形_使用js画图之圆、弧、扇形
  9. LPDDR4的ZQ 校准
  10. 数据压缩算法该如何选择?
  11. 摩尔定律,贝尔定律,吉尔德定律,麦特卡尔夫定律
  12. java thread detach,C++语法学习笔记四十三:线程启动、结束,创建线程多法、join,detach...
  13. Codeforces Round #643 (Div. 2) E. Restorer Distance 题解(三分)
  14. 如何设置计算机的网络参数,如何为计算机新手简单地设置路由器的基本参数
  15. 当前时间显示器(代码屏显)
  16. matplotlib 入门之Sample plots in Matplotlib
  17. H5 CSS引入方式 行内样式表
  18. 上行短信 写入mysql_学习-短信的上行(MO)和下行(MT)详解
  19. python怎么做网站6_网站开发学习Python实现-Django学习-自学注意(6.1.3)
  20. fatal error: sdf sdf.hh: No such file or directory include sdf sdf.hh 解决办法(Gazebo9)

热门文章

  1. cookiejar包_「cookiejar」http.cookiejar库之CookieJar - seo实验室
  2. 天猫智能插座《转换器》爆改WIFI插座接入Homeassistant
  3. DC-005电源插座有三个引脚分别要怎么接?
  4. 锐炬显卡可以linux吗,大势所趋!Intel锐炬显卡让你抛弃独显
  5. 交叉熵和mse_交叉熵 相对熵(KL散度/互熵)
  6. 叮,您有一份防薅羊毛攻略已送达。
  7. 博看文思大骗子,大家别上当
  8. F12 开发人员工具控制台错误消息
  9. CSVReader读取数据缺失
  10. 全新概念的国际学习平台诞生了