一、     MySQL Cluster概述

MySQL Cluster 是一种技术,该技术允许在无共享的系统中部署“内存中”数据库的 Cluster 。通过无共享体系结构,系统能够使用廉价的硬件,而且对软硬件无特殊要求。此外,由于每个组件有自己的内存和磁盘,不存在单点故障。MySQL Cluster 由一组计算机构成,每台计算机上均运行着多种进程,包括MySQL服务器,NDB Cluster 的数据节点,管理服务器,以及(可能)专门的数据访问程序。关于 Cluster 中这些组件的关系,

“NDB” 是一种“内存中”的存储引擎,它具有可用性高和数据一致性好的特点。

ndb支持较为广泛的平台及操作系统,且经过多年的发展,已经可以应用于生产环境;

ndb引擎通过tcp协议交换群集数据;ndb不需要传统的共享存储设备,而是通过 专门的 ndbd数据存储引擎 来模拟共享存储;ndbd存储引擎支持 自动配置、多个数据复本、数据分区、自动分组等功能;ndb提供专门的管理工具集。

  1. 管理(MGM)节点

管理节点的作用是管理MySQL Cluster内的其他节点,如提供配置数据、启动并停止节点、运行备份等。由于这类节点负责管理其他节点的配置,应在启动其他节点之前首先启动管理节点。MGM节点是用命令“ndb_mgmd”启动的。

管理客户端:管理客户端与管理服务器相连,并提供了启动和停止节点、启动和停止消息跟踪(仅调试版本)、显示节点版本和状态、启动和停止备份等的命令。

2.  数据节点:

数据节点用于保存 Cluster的数据。数据节点的数目与副本的数目相关,是片段的倍数。例如,对于两个副本,每个副本有两个片段,那么就有4个数据节点。不过没有必要设置多个副本。数据节点是用命令“ndbd”启动的。

3.  SQL节点:

用于访问 Cluster数据的节点。对于MySQL Cluster,客户端节点是使用NDB Cluster存储引擎的传统MySQL服务器。通常,SQL节点是使用命令“mysqld –ndbcluster”启动的,或将“ndbcluster”添加到“my.cnf”后使用“mysqld”启动。

注意:存储节点和SQL节点可以安装在一台服务器上,管理节点也可以和SQL安装在一台机器上,一般而言,管理节点单独安装。

管理节点(MGM)                   进程名ndb_mgmd

数据节点(Data Nodes)        进程名ndbd

SQL节点(Sql Nodes)           进程名mysqld

二、     MySQL Cluster安装过程

1         规划节点安装

节点

对应的IP和端口

管理节点(1个)

192.168.0.50

SQL节点 (2个)

192.168.0.51:3306

192.168.0.52:3306

数据节点 (2个)

192.168.0.51

192.168.0.52

2         下载安装包和解压

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

我们选用MySQL Cluster 7.1.34

解压:tar –zxvf  mysql-cluster-gpl-7.1.34-linux-i686-glibc23.tar.gz

将目录移动并更名:

mv mysql-cluster-gpl-7.1.34-linux-i686-glibc23 /usr/local/mysql

在192.168.0.51和192.168.0.52上做相同操作

3      管理节点和数据节点的安装

1) 添加mysql用户和组,因为MySQL服务器启动需要mysql用户和组,代码:

groupadd mysql
useradd -g mysql mysql

2)修改目录权限【/usr/local/mysql】将/usr/local/mysql目录的用户和组赋予mysql,代码:

chown –R mysql:mysql  /usr/local/mysql

3) 在/var/lib目录下建立一个mysql-cluster目录,用于存储ndb的数据文件,并把权限赋予mysql用户和组,代码如下:

mkdir  /var/lib/mysql-cluster

chown –R mysql:mysql  /var/lib/mysql-cluster

在192.168.0.51和192.168.0.52上重复步骤1)2)3)

4) 在192.168.0.50的/etc中建立config.ini管理节点配置文件,vim config.ini,config.ini文件内容如下

#管理节点的默认连接端口
[tcp default]
portnumber=2202
[ndbd default]
#每个数据节点的副本数2
NoOfReplicas=2
#ndb数据文件的存储位置
datadir=/var/lib/mysql-cluster/
[ndb_mgmd default]
#管理节点目录
datadir=/var/lib/mysql-cluster/
[ndb_mgmd]
#管理节点ID为1
Id=1
hostname=192.168.0.50
[ndbd]
#数据节点ID为2
Id=2
#数据节点IP
hostname=192.168.0.51
#数据节点目录
datadir=/usr/local/mysql/data/
[ndbd]
#数据节点ID为3
Id=3
#数据节点IP
hostname=192.168.0.52
#数据节点目录
datadir=/usr/local/mysql/data/
[mysqld]
[mysqld]

5) 在192.168.0.51和192.168.0.52的/etc目录下建立my.cnf文件。

[client]
socket =/tmp/mysql.sock
[mysqld]
default-storage-engine=ndbcluster
#运行NDB存储引擎
ndbcluster
#指定管理节点
ndb-connectstring=192.168.0.50
[ndbd]
connectstring=192.168.0.51,192.168.0.52
[mysql_cluster]
ndb-connectstring=192.168.0.50

三、     MySQL Cluster环境启动

注意启动顺序:首先是管理节点,然后是NDBD节点,最后是SQL节点。

1)  启动管理节点(192.168.0.50)

ndb_mgmd -f /var/lib/mysql-cluster/config.ini

2)  启动数据节点(192.168.0.51和192.168.0.52)

/usr/local/mysql/bin/ndbd –initial

3)  启动SQL节点(192.168.0.51和192.168.0.52)

/usr/local/mysql/bin/mysqld_safe --user=mysql

4)   去启动管理节点(192.168.0.50) 查看

Mdb_mgm 后show。

四、     MySQL Cluster的测试

注意事项:1.表必须用ENGINE=NDB或ENGINE=NDBCLUSTER选项创建,或用ALTER TABLE选项更改,以使用NDB Cluster存储引擎在 Cluster内复制它们。如果使用mysqldump的输出从已有数据库导入表,可在文本编辑器中打开SQL脚本,并将该选项添加到任何表创建语句,或用这类选项之一替换任何已有的ENGINE(或TYPE)选项。

2.另外还请记住,每个NDB表必须有一个主键。如果在创建表时用户未定义主键,NDB Cluster存储引擎将自动生成隐含的主键。(注释:该隐含 键也将占用空间,就像任何其他的表索引一样。由于没有足够的内存来容纳这些自动创建的键,出现问题并不罕见)。

3.当你在一个节点上运行create database mydb;你去其他sql node上执行show databases;将不能看到mydb,你需要创建它,然后use mydb; show tables;你将看到同步的表。

参考http://www.cnblogs.com/StanBlogs/archive/2011/06/14/2080986.html中测试环境

在节点192.168.0.51上面:

为了让表在cluster中正常复制,创建一个表必须使用ndbcluster引擎(engine=ndb Or engine=ndbcluster)方法如下:

mysql>use test

mysql>create table teacher(t_id int) engine=ndb;

如果是一个已经存在的表,用alter table修改表的引擎。

mysql>alter table student engine=ndb;

插入一条数据:

mysql>insert into teacher values(133);

然后在节点上:

mysql>select * from teacher;

五、     MySQL Cluster关闭

关闭顺序是首先是管理节点,然后是SQL节点,最后是数据节点。在管理节点中的ndb_mgm> 提示符下输入 shutdown即可,这时会显示各节点的关闭信息,再输入exit即可退出ndb_mgm管理。

MySQL Cluster配置概述的更多相关文章

  1. MySQL Cluster 配置详细介绍

    在上篇文章已经详细说明了MySQL Cluster搭建与测试,现在来说说详细的配置参数.在MySQL Cluster 环境的配置文件 config.ini 里面,每一类节点都有两个(或以上)的相应配置 ...

  2. mysql cluster配置

    依赖包要求:cmake     gcc    gcc-c++     ncurses     Perl     ncurses-devel 在7.3以及更高的版本中, WITH_NDB_JAVA是默认 ...

  3. Mysql Cluster配置基本篇

    一.下载mysql-cluster 从mysql官网下载对应的mysql-cluster 二.配置管理节点 1.解压mysql-cluster,找到解压文件中的ndb_mgm和ndb_mgmd 2.复 ...

  4. MySQL Cluster 7.3.5 集群配置参数优化(优化篇)

    按照前面的教程:MySQL Cluster 7.3.5 集群配置实例(入门篇),可快速搭建起基础版的MySQL Cluster集群,但是在生成环境中,还是有很多问题的,即配置参数需要优化下, 当前生产 ...

  5. Windows Server 2008R2配置MySQL Cluster

    目录 配置环境 相关知识 配置过程 配置 ini参数解释 启动集群 检查配置 同步测试 故障测试 写在之后 配置环境 VMware:(版本10.0.01) 操作系统:Windows Server 20 ...

  6. mysql cluster (mysql 集群)安装配置方案(转)

    一.准备 1.准备服务器 计划建立有5个节点的MySQL CLuster体系,需要用到5台服务器,但是我们做实验时没有这么多机器,可以只用2台,我就是一台本机,一台虚拟机搭建了有5个节点的MySQL ...

  7. mysql cluster 安装配置方案

    mysql cluster (mysql 集群)安装配置方案   一.准备 1.准备服务器 计划建立有5个节点的MySQL CLuster体系,需要用到5台服务器,但是我们做实验时没有这么多机器,可以 ...

  8. MySQL Cluster搭建与测试

    MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和Oracle Real Cluster Ap ...

  9. MySQL Cluster 集群

    本文转载 http://www.cnblogs.com/gomysql/p/3664783.html MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅 ...

随机推荐

  1. jquery-migrate.js

    这个插件可以用来检测和恢复在jQuery1.9版本中已删除或已过时的API.

  2. C primer plus 练习题 第一章

    1. #include <stdio.h> int main() { //将英寸转换为厘米 1英寸=2.54厘米 int inch; printf("请输入英寸:"); ...

  3. Ranorex入门指南

    Ranorex入门指南 http://automationqa.com/forum.php?mod=viewthread&tid=2766&fromuid=29

  4. QT编写DLL给外部程序调用,提供VC/C#/C调用示例(含事件)

    最近这阵子,接了个私活,封装一个开发包俗称的SDK给客户调用,查阅了很多人家的SDK,绝大部分用VC编写,而且VC6.0居多,估计也是为了兼容大量的XP用户及IE浏览器,XP自带了VC6.0运行库,所 ...

  5. Approvals for EBS 1.4 Now Available

    If you haven't been following the excellent Workflow blog, you might have missed the announcement ab ...

  6. CSS的sprite和单位

    (1).关于css sprite技术 比方说: 有个论坛频道,其中有个一些论坛特有的小图标(火啊,顶啊之类),基于整站小图标大团结的思想,这些小图标也放在了那个icon背景图片上了.然而,数年下来,我 ...

  7. NSDictionary 的有序性 (by the key in some rule)

    NSDictionary 的有序性: (by the key in some rule) NSDictionary*myDictionary =[NSDictionary dictionaryWith ...

  8. 天猫浏览型应用的CDN静态化架构演变

    原文链接:http://www.csdn.net/article/2014-01-22/2818227-CDN-Architecture 在天猫双11活动中,商品详情.店铺等浏览型系统,通常会承受超出 ...

  9. 让我们一起Go(十二)

    前言: 上篇中,我们讲到了在Go语言中如何定义方法,今天,我们将进一步深入Go语言的面向对象编程. 一.Go语言中的接口 首先来看一个最基本的接口: 和定义一个结构体类似,只不过将struct换成了i ...

  10. Web services 安全 - HTTP Basic Authentication

    根据 RFC2617 的规定,HTTP 有两种标准的认证方式,即,BASIC 和 DIGEST.HTTP Basic Authentication 是指客户端必须使用用户名和密码在一个指定的域 (Re ...