热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

MySQLCluster开发环境简明部署(中文)

MySQLCluster开发环境简明部署(中文),作为在开发环境上第一次部署,还是以测试为主要目的。一个完整的MySQLCluster由MySQ

MySQL Cluster 开发环境简明部署(中文),作为在开发环境上第一次部署,还是以测试为主要目的。一个完整的 MySQL Cluster 由 MySQ

主要内容

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

1. 获取

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

MySQL Cluster 的英文部署测试手册下载地址:

免费下载地址在

用户名与密码都是

具体下载目录在 /2012年资料/2月/29日/MySQL Cluster 开发环境简明部署(中文)/

2. 安装

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

michael@linux:~$ tar xvf mysql-cluster-gpl-7.2.4-linux2.6-x86_64.tar 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 三部分组成。首先我们为它们创建一些必须的目录:

michael@linux:~$ mkdir mysql-cluster michael@linux:~$ cd mysql-cluster michael@linux:~$ mkdir conf ndb_data mysqld_data

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

config.ini

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

[mysqld] ndbcluster datadir=/home/user1/my_cluster/mysqld_data basedir=/home/user1/mysqlc port=5050 my.cnf

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

[ndb_mgmd] hostname=localhost datadir=/home/user1/my_cluster/ndb_data NodeId=1 [ndbd default] noofreplicas=2 datadir=/home/user1/my_cluster/ndb_data [ndbd] hostname=localhost NodeId=3 [ndbd] hostname=localhost NodeId=4 [mysqld] NodeId=50

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

~ +-- /mysql-cluster-gpl-7.2.4-linux2.6-x86_64 +-- /mysqlc -> mysql-cluster-gpl-7.2.4-linux2.6-x86_64 +-- /mysql-cluster +-- /conf +-- /ndb_data +-- /mysqld_data 4. 运行

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

  • Management Node
  • Data Nodes
  • MySQL Server
  • 命令如下:

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

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

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

    输出如下:

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

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

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

    输出信息如下:

    120223 15:29:02 InnoDB: The InnoDB memory heap is disabled 120223 15:29:02 InnoDB: Mutexes and rw_locks use GCC atomic builtins 120223 15:29:02 InnoDB: Compressed tables use zlib 1.2.3 120223 15:29:02 InnoDB: Using Linux native AIO 120223 15:29:02 InnoDB: Initializing buffer pool, size = 128.0M 120223 15:29:02 InnoDB: Completed initialization of buffer pool 120223 15:29:02 InnoDB: highest supported file format is Barracuda. 120223 15:29:02 InnoDB: Waiting for the background threads to start 120223 15:29:03 InnoDB: 1.1.8 started; log sequence number 1595675 120223 15:29:04 [Note] NDB: NodeID is 50, management server 'localhost:1186' 120223 15:29:04 [Note] NDB[0]: NodeID: 50, all storage nodes connected 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 120223 15:29:04 [Note] Starting Cluster Binlog Thread 120223 15:29:04 [Note] Event Scheduler: Loaded 0 events 120223 15:29:04 [Note] $HOME/mysqlc/bin/mysqld: ready for connections. Version: '5.5.19-ndb-7.2.4-gpl' socket: '/tmp/mysql.sock' port: 5050 MySQL Cluster Community Server (GPL) 120223 15:29:05 [Note] NDB: Creating mysql.ndb_schema 120223 15:29:08 [Note] NDB Binlog: CREATE TABLE Event: REPL$mysql/ndb_schema 120223 15:29:09 [Note] NDB Binlog: logging ./mysql/ndb_schema (UPDATED,USE_WRITE) 120223 15:29:09 [Note] NDB: Creating mysql.ndb_apply_status 120223 15:29:09 [Note] NDB Binlog: CREATE TABLE Event: REPL$mysql/ndb_apply_status 120223 15:29:09 [Note] NDB Binlog: logging ./mysql/ndb_apply_status (UPDATED,USE_WRITE) 120223 15:29:09 [Note] NDB: missing frm for mysql.ndb_index_stat_sample, discovering... 120223 15:29:09 [Note] NDB: missing frm for mysql.ndb_index_stat_head, discovering... 2012-02-23 15:29:10 [NdbApi] INFO -- Flushing incomplete GCI:s <579/14 2012-02-23 15:29:10 [NdbApi] INFO -- Flushing incomplete GCI:s <579/14 120223 15:29:10 [Note] NDB Binlog: starting log at epoch 579/14 120223 15:29:10 [Note] NDB Binlog: ndb tables writable 5. 测试

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

    michael@linux:~$ $HOME/mysqlc/bin/mysql -h 127.0.0.1 -P 5050 mysql> create database clusterdb; mysql> use clusterdb; mysql> insert into simples values (1),(2),(3),(4); mysql> select * from simples; +----+ | id | +----+ | 3 | | 1 | | 2 | | 4 | +----+ 6. 停止

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

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

    如果提示:

    /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。

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

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

    120223 16:44:11 [Note] /home/michael/mysqlc/bin/mysqld: Normal shutdown michael@linux:~/mysql-cluster$ 120223 16:44:11 [Note] Event Scheduler: Purging the queue. 0 events 120223 16:44:13 [Warning] /home/michael/mysqlc/bin/mysqld: Forcing close of thread 2 user: 'michael' 120223 16:44:13 [Note] Stopping Cluster Utility thread 120223 16:44:13 [Note] Stopping Cluster Index Stats thread 120223 16:44:13 [Note] Stopping Cluster Binlog 120223 16:44:13 [Note] Stopping Cluster Index Statistics thread 120223 16:44:14 InnoDB: Starting shutdown... 120223 16:44:15 InnoDB: Shutdown completed; log sequence number 1595675 120223 16:44:15 [Note] /home/michael/mysqlc/bin/mysqld: Shutdown complete 7. 总结
  • 有序启动:Management Node,Data Nodes,MySQL Server
  • 配置项与各节点的对应
  • 每个结点都单独启动
  • Management Node 提供状态查看等多种功能

  • 推荐阅读
    • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
    • Metasploit攻击渗透实践
      本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
    • 学习SLAM的女生,很酷
      本文介绍了学习SLAM的女生的故事,她们选择SLAM作为研究方向,面临各种学习挑战,但坚持不懈,最终获得成功。文章鼓励未来想走科研道路的女生勇敢追求自己的梦想,同时提到了一位正在英国攻读硕士学位的女生与SLAM结缘的经历。 ... [详细]
    • 近年来,大数据成为互联网世界的新宠儿,被列入阿里巴巴、谷歌等公司的战略规划中,也在政府报告中频繁提及。据《大数据人才报告》显示,目前全国大数据人才仅46万,未来3-5年将出现高达150万的人才缺口。根据领英报告,数据剖析人才供应指数最低,且跳槽速度最快。中国商业结合会数据剖析专业委员会统计显示,未来中国基础性数据剖析人才缺口将高达1400万。目前BAT企业中,60%以上的招聘职位都是针对大数据人才的。 ... [详细]
    • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
    • Linux重启网络命令实例及关机和重启示例教程
      本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
    • 本文主要讨论了在xps15上安装双系统win10和MacOS后,win10无法正常更新的问题。分析了可能的引导问题,并提供了解决方法。 ... [详细]
    • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
    • Centos7.6安装Gitlab教程及注意事项
      本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
    • 树莓派Linux基础(一):查看文件系统的命令行操作
      本文介绍了在树莓派上通过SSH服务使用命令行查看文件系统的操作,包括cd命令用于变更目录、pwd命令用于显示当前目录位置、ls命令用于显示文件和目录列表。详细讲解了这些命令的使用方法和注意事项。 ... [详细]
    • Python语法上的区别及注意事项
      本文介绍了Python2x和Python3x在语法上的区别,包括print语句的变化、除法运算结果的不同、raw_input函数的替代、class写法的变化等。同时还介绍了Python脚本的解释程序的指定方法,以及在不同版本的Python中如何执行脚本。对于想要学习Python的人来说,本文提供了一些注意事项和技巧。 ... [详细]
    • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
    • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
    • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
      本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
    • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
    author-avatar
    mobiledu2502890883
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有