一、准备

集群:

192.168.1.191  管理节点
192.168.1.192  管理节点
192.168.1.193  数据节点和API节点  
192.168.1.194  数据节点和API节点

安装包:mysql-cluster-gpl-7.5.5-linux-glibc2.5-x86_64.tar.gz

二、安装

安装mysql管理节点

cd mysql-cluster-gpl-7.5.-linux-glibc2.-x86_64/

sudo cp bin/ndb_mgm* /usr/local/bin

cd /usr/local/bin

sudo mkdir /var/lib/mysql-cluster

sudo mkdir /usr/local/mysql

sudo vi /var/lib/mysql-cluster/config.ini 

sudo chmod -r 777 /var/lib/mysql-cluster/
sudo chmod -R 777 /usr/local/mysql/
config.ini的如下:
[ndbd default]
NoOfReplicas=
DataMemory=512M
IndexMemory=18M [ndb_mgmd]
HostName=192.168.1.191
DataDir=/var/lib/mysql-cluster
[ndb_mgmd]
HostName=192.168.1.192
DataDir=/var/lib/mysql-cluster
[ndbd]
HostName=192.168.1.193
DataDir=/var/lib/mysql-cluster [ndbd]
HostName=192.168.1.194
DataDir=/var/lib/mysql-cluster
191上执行:/usr/local/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini --initial
192上执行:/usr/local/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini

成功如下:

测试:

cd /usr/local/bin

ndb_mgm

show

#为了保证数据节点等和管理节点通信 需要开启 1186 端口

 安装mysql数据节点 

192.168.1.193  数据节点
192.168.1.194  数据节点

sudo groupadd mysql

sudo useradd -g mysql -s /bin/false mysql

sudo mv mysql-cluster-gpl-7.5.6-linux-glibc2.5-x86_64/ /usr/local/mysql

sudo mkdir /var/lib/mysql-cluster

 sudo chown root:mysql /var/lib/mysql-cluster

 sudo chmod -R 777 /var/lib/mysql-cluster/

 sudo vi /etc/my.cnf

my.cnf内容如下:

[client]
[mysqld]
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
ndbcluster
ndb-connectstring=192.168.1.191
ndb-connectstring=192.168.1.192

[mysql_cluster]
ndb-connectstring=192.168.1.191
ndb-connectstring=192.168.1.192

cd /usr/local/mysql/

bin/ndbd --initial #数据节点初始化

测试:在管理节点上

cd /usr/local/bin

ndb_mgm

show

安装API(mysqld)节点

初始化mysql

cd /usr/local/mysql/

./bin/mysqld --initialize

会生成临时密码,记好临时密码,之后需要用到

support-files/mysql.server start #启动mysql
support-files/mysql.server status #查看mysql状

测试:在管理节点上

cd /usr/local/bin

ndb_mgm

show

最后的设置:在管理节点上

cd /usr/local/bin

ndb_mgm

shutdown #关掉 关掉管理节点和数据节点的服务

cd /usr/local/mysql
./bin/mysql -u root -p #随后输入密码 密码是之前生成的临时随机密码

修改root 密码,改远程访问,外部连接时 需要开启 3306端口

SET PASSWORD = PASSWORD('your new password');

use mysql;
update user set host = '%' where user = 'root'; #然后改远程访问
FLUSH PRIVILEGES;

启动集群:

ps:在数据节点没有全部启动之前, 不要启动API集群

#启动管理节点
/usr/local/bin/ ndb_mgmd #启动数据节点
cd /usr/loca/mysql/
./bin/ndbd #启动api节点
cd /usr/loca/mysql/
./support-files/mysql.server start

测试:

test同步成功,test01同步失败

默认数据库自动同步,创建表的时候主要选择数据引擎选择 ndbcluster 才会同步

暴力测试:

各种 kill 进程 ,只要有一个数据节点存活,数据都会同步和保存,当然前提是只要有个API节点存活,才可以访问。

Mysql分布式集群的更多相关文章

  1. MySQL分布式集群之MyCAT(转)

    原文地址:http://blog.itpub.net/29510932/viewspace-1664499/ 隔了好久,才想起来更新博客,最近倒腾的数据库从Oracle换成了MySQL,研究了一段时间 ...

  2. 如何搭建一个 MySQL 分布式集群

    1.准备集群搭建环境 使用6台虚拟机来搭建 MySQL分布式集群 ,相应的实验环境与对应的MySQL节点之间的对应关系如下图所示: 管理节点(MGM):这类节点的作用是管理MySQLCluster内的 ...

  3. MySQL分布式集群之MyCAT(三)rule的分析【转】

    首先写在最前面,MyCAT1.4的alpha版本已经发布了,这里面修复了不少的bug,也完善了一细节,之前两篇博客已经做了一些修改 ---------------------------------- ...

  4. MySQL分布式集群之MyCAT(二)【转】

    在第一部分,有简单的介绍MyCAT的搭建和配置文件的基本情况,这一篇详细介绍schema的一些具体参数,以及实际作用        首先贴上自己测试用的schema文件,双引号之前的反斜杠不会消除,姑 ...

  5. MySQL分布式集群之MyCAT(一)简介【转】

    隔了好久,才想起来更新博客,最近倒腾的数据库从Oracle换成了MySQL,研究了一段时间,感觉社区版的MySQL在各个方面都逊色于Oracle,Oracle真的好方便!好了,不废话,这次准备记录一些 ...

  6. 抄来的,占个位儿【百度架构师是怎样搭建MySQL分布式集群】

    1.准备集群搭建环境 使用6台虚拟机来搭建MySQL分布式集群,相应的实验环境与对应的MySQL节点之间的对应关系如下图所示:     管理节点(MGM):这类节点的作用是管理MySQLCluster ...

  7. mysql分布式集群实现原理

    做MySQL集群,例如:利用mysql cluster ,mysql proxy,mysql replication,drdb等等 有人会问mysql集群,根分表有什么关系吗?虽然它不是实际意义上的分 ...

  8. 【Database】Mysql分布式集群学习笔记

    一.sql 的基本操作 (2018年11月29日,笔记) (1)数据库相关操作 创建数据库.查看数据库.删除数据库 #. 创建数据库 create database mytest default ch ...

  9. MySQL Cluster 集群

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

随机推荐

  1. 自定义 Word 默认的 Normal.dotm 模板、更改 Word 默认字体、更改 Word 默认样式(16)

    1. 引言 以Office 2016为例. 有没有遇见这样的问题: 每次新建一个 Word 空白文档打开后字体默认是等线,段落默认是单倍行距,默认标题也不是自己想要的样式,等一系列问题.每次打开都要调 ...

  2. Django模板语言中静态文件路径的灵活写法

    如图,我们看到的时html页面中静态文件的路径,其中/static/是settings.py中的设置: 假设我们将settings.py中的/static/改变了,这样的话我们还需要将html中的/s ...

  3. 爬虫请求库之requests库

    一.介绍 介绍:使用requests可以模拟浏览器的请求,比之前的urllib库使用更加方便 注意:requests库发送请求将网页内容下载下来之后,并不会执行js代码,这需要我们自己分析目标站点然后 ...

  4. mysql实践一:SQL基础

    mysql简介 mysql是有名的开放源代码关系型数据库.它最早是AB公司开源的,后来到Sun公司手中.之后Sun公司被Oracle公司收购,mysql就归Oracle所有.从此mysql走向商业化, ...

  5. (四)pdf的构成之文件体(树图)

    pdf的文件体类似于一个大树 有个根对象(catalog),该对象中保存着PDF的很多基本信息,并通过间接引用,辐射到所有的间接对象. (下图是大概的树形状)

  6. -Dmaven.test.skip=true 和 -DskipTests

    -DskipTests,不执行测试用例,但编译测试用例类生成相应的class文件至target/test-classes下. -Dmaven.test.skip=true,不执行测试用例,也不编译测试 ...

  7. idea多级目录不展开的问题

    遇见了一个坑,idea新建的包,和它的上级包重叠在了一起,无法形成树状结构 原因呢,还是因为自己的不细心了,解决方案很简单,下面的是原情况 解决方案,点击左侧栏右上角的设置图表,注意看红框内 把第一行 ...

  8. 关闭 OSX 10.11 SIP (System Integrity Protection) 功能

    关闭 OSX 10.11 SIP (System Integrity Protection) 功能 来源 https://cms.35g.tw/coding/%E9%97%9C%E9%96%89-os ...

  9. Java调用WebService方法总结(9,end)--Http方式调用WebService

    Http方式调用WebService,直接发送soap消息到服务端,然后自己解析服务端返回的结果,这种方式比较简单粗暴,也很好用:soap消息可以通过SoapUI来生成,也很方便.文中所使用到的软件版 ...

  10. Java High Level REST Client 使用示例

    概述 ES 在 7.0 版本开始将废弃 TransportClient,8.0 版本开始将完全移除 TransportClient,取而代之的是 High Level REST Client,官方文档 ...