MySQL Cluster开发环境简明部署

主要内容

1. 获取; 2. 安装; 3. 配置; 4. 运行; 5. 测试; 6. 停止; 7. 总结

1. 获取

这个不必多言吧,到 MySQL 网站上面下载就是了。MySQL Cluster 的英文部署测试手册很简明,这里和其内容基本一样。喜欢读英文版的朋友可以直接下载,略过本文。

2. 安装

先解压,然后创建一个 symbolic link:

  1. michael@linux:~$ tar xvf mysql-cluster-gpl-7.2.4-linux2.6-x86_64.tar  
  2. michael@linux:~$ ln -s mysql-cluster-gpl-7.2.4-linux2.6-x86_64 mysqlc 

如果你愿意,可以将~/mysqlc/bin加入到你的 path 里,方便使用。

3. 配置

作为在开发环境上第一次部署,还是以测试为主要目的。一个完整的 MySQL Cluster 由 MySQL Server,Data Nodes,Management Node 三部分组成。首先我们为它们创建一些必须的目录:

  1. michael@linux:~$ mkdir mysql-cluster  
  2. michael@linux:~$ cd mysql-cluster  
  3. michael@linux:~$ mkdir conf ndb_data mysqld_data 

然后在conf目录下创建如下两个文件,分别是config.inimy.cnf,内容如下:

config.ini

用于 MySQL Server 的配置,端口号port根据你自己的情况设定。

  1. [mysqld]  
  2. ndbcluster  
  3. datadir=/home/user1/my_cluster/mysqld_data  
  4. basedir=/home/user1/mysqlc  
  5. port=5050  

my.cnf

该文件用于配置各结点的 NodeId 和 Data Nodes 与 Management Node 的数据目录。

  1. [ndb_mgmd]  
  2. hostname=localhost  
  3. datadir=/home/user1/my_cluster/ndb_data  
  4. NodeId=1  
  5.  
  6. [ndbd default]  
  7. noofreplicas=2  
  8. datadir=/home/user1/my_cluster/ndb_data  
  9.  
  10. [ndbd]  
  11. hostname=localhost  
  12. NodeId=3  
  13.  
  14. [ndbd]  
  15. hostname=localhost  
  16. NodeId=4  
  17.  
  18. [mysqld]  
  19. NodeId=50  

这时你的目录结构应该如下:

  1. ~  
  2. +-- /mysql-cluster-gpl-7.2.4-linux2.6-x86_64  
  3. +-- /mysqlc -> mysql-cluster-gpl-7.2.4-linux2.6-x86_64  
  4. +-- /mysql-cluster  
  5.     +-- /conf  
  6.     +-- /ndb_data  
  7.     +-- /mysqld_data  

4. 运行

MySQL Cluster 的启动顺序是有要求的,如下:

  1. Management Node

  2. Data Nodes

  3. MySQL Server

命令如下:

  1. michael@linux:~$ cd ../mysql-cluster  
  2. michael@linux:~/mysql-cluster$ $HOME/mysqlc/bin/ndb_mgmd -f conf/config.ini --initial --configdir=$HOME/mysql-cluster/conf/  
  3. michael@linux:~/mysql-cluster$ $HOME/mysqlc/bin/ndbd -c localhost:1186  
  4. michael@linux:~/mysql-cluster$ $HOME/mysqlc/bin/ndbd -c localhost:1186  

检查已经启动的结点的状态,命令为:

  1. poecahnt@linux:~$ $HOME/mysqlc/bin/ndb_mgm -e show  

输出如下:

  1. Connected to Management Server at: localhost:1186  
  2. Cluster Configuration  
  3. ---------------------  
  4. [ndbd(NDB)]     2 node(s)  
  5. id=3    @127.0.0.1  (mysql-5.5.19 ndb-7.2.4, Nodegroup: 0, Master)  
  6. id=4    @127.0.0.1  (mysql-5.5.19 ndb-7.2.4, Nodegroup: 0)  
  7.  
  8. [ndb_mgmd(MGM)] 1 node(s)  
  9. id=1    @127.0.0.1  (mysql-5.5.19 ndb-7.2.4)  
  10.  
  11. [mysqld(API)]   1 node(s)  
  12. id=50   @127.0.0.1  (mysql-5.5.19 ndb-7.2.4)  

表示已经可以启动 MySQL Server 了。最后启动 MySQL Server,命令为:

  1. michael@linux:~/mysql-cluseter$ $HOME/mysqlc/bin/mysqld --defaults-file=conf/my.cnf &  

输出信息如下:

  1. 120223 15:29:02 InnoDB: The InnoDB memory heap is disabled  
  2. 120223 15:29:02 InnoDB: Mutexes and rw_locks use GCC atomic builtins  
  3. 120223 15:29:02 InnoDB: Compressed tables use zlib 1.2.3  
  4. 120223 15:29:02 InnoDB: Using Linux native AIO  
  5. 120223 15:29:02 InnoDB: Initializing buffer pool, size = 128.0M  
  6. 120223 15:29:02 InnoDB: Completed initialization of buffer pool  
  7. 120223 15:29:02 InnoDB: highest supported file format is Barracuda.  
  8. 120223 15:29:02  InnoDB: Waiting for the background threads to start  
  9. 120223 15:29:03 InnoDB: 1.1.8 started; log sequence number 1595675  
  10. 120223 15:29:04 [Note] NDB: NodeID is 50, management server 'localhost:1186' 
  11. 120223 15:29:04 [Note] NDB[0]: NodeID: 50, all storage nodes connected  
  12. 120223 15:29:04 [Warning] NDB: server id set to zero - changes logged to bin log with   server id zero will be logged with another server id by slave mysqlds  
  13. 120223 15:29:04 [Note] Starting Cluster Binlog Thread  
  14. 120223 15:29:04 [Note] Event Scheduler: Loaded 0 events  
  15. 120223 15:29:04 [Note] $HOME/mysqlc/bin/mysqld: ready for connections.  
  16. Version: '5.5.19-ndb-7.2.4-gpl'  socket: '/tmp/mysql.sock'  port: 5050  MySQL Cluster Community Server (GPL)  
  17. 120223 15:29:05 [Note] NDB: Creating mysql.ndb_schema  
  18. 120223 15:29:08 [Note] NDB Binlog: CREATE TABLE Event: REPL$mysql/ndb_schema  
  19. 120223 15:29:09 [Note] NDB Binlog: logging ./mysql/ndb_schema (UPDATED,USE_WRITE)  
  20. 120223 15:29:09 [Note] NDB: Creating mysql.ndb_apply_status  
  21. 120223 15:29:09 [Note] NDB Binlog: CREATE TABLE Event: REPL$mysql/ndb_apply_status  
  22. 120223 15:29:09 [Note] NDB Binlog: logging ./mysql/ndb_apply_status (UPDATED,USE_WRITE)  
  23. 120223 15:29:09 [Note] NDB: missing frm for mysql.ndb_index_stat_sample, discovering...  
  24. 120223 15:29:09 [Note] NDB: missing frm for mysql.ndb_index_stat_head, discovering...  
  25. 2012-02-23 15:29:10 [NdbApi] INFO     -- Flushing incomplete GCI:s < 579/14  
  26. 2012-02-23 15:29:10 [NdbApi] INFO     -- Flushing incomplete GCI:s < 579/14  
  27. 120223 15:29:10 [Note] NDB Binlog: starting log at epoch 579/14  
  28. 120223 15:29:10 [Note] NDB Binlog: ndb tables writable  

5. 测试

连接 MySQL Server 进行测试,确认可以用ndb存储引擎来创建数据库中的表,如下:

  1. michael@linux:~$ $HOME/mysqlc/bin/mysql -h 127.0.0.1 -P 5050  
  2. mysql> create database clusterdb;  
  3. mysql> use clusterdb;  
  4. mysql> insert into simples values (1),(2),(3),(4);  
  5. mysql> select * from simples;  
  6.  
  7.         +----+  
  8.         | id |  
  9.         +----+  
  10.         |  3 |  
  11.         |  1 |  
  12.         |  2 |  
  13.         |  4 |  
  14.         +----+  

6. 停止

MySQL Cluster 必须手动停止,Data Nodes 可以用 ndb_mgm 来停止:

  1. michael@linux:~$ $HOME/mysqlc/bin/mysqladmin -h 127.0.0.1 -P 5050 shutdown  

如果提示:

  1. /home/michael/mysqlc/bin/mysqladmin: shutdown failed; error: 'Access denied; you need (at least one of) the SHUTDOWN privilege(s) for this operation' 

则在shutdown命令前加上sudo

  1. michael@linux:~$ $HOME/mysqlc/bin/ndb_mgm -e shutdown  

正常停止的信息类似如下:

  1. 120223 16:44:11 [Note] /home/michael/mysqlc/bin/mysqld: Normal shutdown  
  2.  
  3. michael@linux:~/mysql-cluster$ 120223 16:44:11 [Note] Event Scheduler: Purging the queue. 0 events  
  4. 120223 16:44:13 [Warning] /home/michael/mysqlc/bin/mysqld: Forcing close of thread 2  user'michael' 
  5.  
  6. 120223 16:44:13 [Note] Stopping Cluster Utility thread  
  7. 120223 16:44:13 [Note] Stopping Cluster Index Stats thread  
  8. 120223 16:44:13 [Note] Stopping Cluster Binlog  
  9. 120223 16:44:13 [Note] Stopping Cluster Index Statistics thread  
  10. 120223 16:44:14  InnoDB: Starting shutdown...  
  11. 120223 16:44:15  InnoDB: Shutdown completed; log sequence number 1595675  
  12. 120223 16:44:15 [Note] /home/michael/mysqlc/bin/mysqld: Shutdown complete  

7. 总结

  1. 有序启动:Management Node,Data Nodes,MySQL Server

  2. 配置项与各节点的对应

  3. 每个结点都单独启动

  4. Management Node 提供状态查看等多种功能

 原文链接:http://blog.csdn.net/poechant/article/details/7289103

【编辑推荐】

  1. MySQL内存表的特性与使用介绍
  2. 利用Java进行MySql数据库的导入和导出
  3. 甲骨文推出MySQL集群7.2
  4. MySQL的四种不同查询的分析
  5. MySQL Workbench 5.2.38发布

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/228097.html<

(0)
运维的头像运维
上一篇2025-04-18 03:40
下一篇 2025-04-18 03:42

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注