码迷,mamicode.com
首页 > 数据库 > 详细

MySQL集群搭建(所有节点在同一台机子上)

时间:2015-05-13 19:38:08      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:

转自:http://www.2cto.com/database/201408/328954.html

加了一些遇到的错误及其解决方法;

------------------------------------------------华丽的分割线--------------------------------------------------------

mysql用来开发中小型项目还是挺好用的,从节约成本的方面来考虑的确是个不错的选择,但是开发并发了比较大的项目显然还是有些吃力的,前几 年解决这种问题通常是通过读写分离来优化数据库,因此出现了amoeba这个东西,现在这个东西已经被弃用了反倒是mysql-cluster-gpl用 的比较多。但是有关mysql集群的配置还是比较繁琐,好多人弄不出来就放弃了,可怕的是网上很多资料都是转载别人的,都没有经过自己实际的验证,简直就 是太坑爹了。这次我打算分享下有关mysql集群的知识。

1 开发准备

下载mysql-cluster-gpl-7.X版本的msi或者exe文件,双击后安装位置随意,安装好之后目录大致如下(ps:可以直接下载免安装版本的)

技术分享

2 创建于集群相关的文件目录

(1)在磁盘上建一个文件夹名称随意,在这个文件夹下面建mgm_data、ndb_data、mysqld_data,建好之后从mysql-cluster-gpl的安装目录下的bin目录下面复制ndb_mgm.exe和ndb_mgmd.exe到该目录下

(2)接着在ndb_data下面建ndb1和ndb2两个文件夹,并从mysql-cluster安装目录下的bin文件夹复制ndbd.exe到ndb1和ndb2文件夹下面

(3)然后在mysqld_data下面建mysqld1和mysqld2两个文件夹

(4)从mysql-cluster下面复制data、share目录,并从bin目录下复制mysqld.exe、mysqladmin.exe到mysqld1和mysqld2文件夹下面

(5)接下来创建两个my.ini文件内容如下

第一个: 

[MYSQLD]
ndbcluster
datadir=D:/mydatabase/my_cluster/mysqld_data/mysqld1/data
basedir=D:/MySQLCluster
port=5000
datadir配置的是数据库的数据目录,basedir配置的是mysql-cluster的安装目录

第二个:

[MYSQLD]
ndbcluster
datadir=D:/mydatabase/my_cluster/mysqld_data/mysqld2/data
basedir=D:/MySQLCluster
port=5001 

第一个my.ini放在mysqld1文件夹下面,第二个则放在mysqld2文件夹下面

3 在基本目录下面创建一个名为config.ini的文件内容如下

[MYSQLD]
Id=21
[MYSQLD]
Id=22
[ndb_mgmd]
hostname=localhost
datadir=D:/mydatabase/my_cluster/mgm_data
id=1
[NDBD DEFAULT]
NoOfReplicas=2 
DataMemory=80M 
IndexMemory=18M 
[ndbd]
hostname=localhost
id=11
[ndbd]
hostname=localhost
id=12
datadir配置的是管理节点的目录,管理节点对数据节点和数据库服务节点进行统一管理

4 启动管理节点

命令为:ndb_mgmd.exe -f config.ini --initial

第一次启动的时候需要加--initial参数,但是后面启动的时候就不需要了

技术分享

PS:启动管理节点时可能会报错,不用管它,是因为其他节点还没有启起来;

4 启动数据节点

分别进入每一个数据节点,也就是ndb1和ndb2目录下执行:ndbd -c localhost:1186

技术分享

以同样的方式启动第二个数据节点

PS:如果提示某文件夹不存在时,在该目录下新建好文件夹即可,然后重新启动;

5 启动mysql服务节点

同样的进入mysql服务节点目录也就是mysqld1和mysqld2目录,执行:mysqld.exe --defaults-file=my.ini

技术分享

还是以相同的方法启动第二个mysql服务节点

以防万一最好进入管理节点输入:ndb_mgm.exe之后在输入show回车,看看节点的状态是否正常

技术分享

如图这种情况就说明节点都正常

6 接下来的工作就简单了,只需打开图形界面工具,连接5000和5001的数据库,接在在5000的这个mysql上随便建一个数据库并创建一张表,这里需 要注意的是表的引擎应该使用ndb才可以。之后添加几条数据,我们可以看到在5001的mysql上也可以看到在5000上创建的数据库,且表的信息一致

技术分享

为了能顺利执行各种命令,建议使用管理员身份执行命令,否则很有可能出现命令执行不成功的情况

 

 

? 根据上述方法搭建好了集群,但是没有同步成功,明天看看是什么原因,再做补充!

 

MySQL集群搭建(所有节点在同一台机子上)

标签:

原文地址:http://www.cnblogs.com/splvxh/p/4501028.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!