`
Poechant
  • 浏览: 227498 次
博客专栏
Bebe66e7-3a30-3fc9-aeea-cfa3b474b591
Nginx高性能Web服务...
浏览量:24243
5738817b-23a1-3a32-86de-632d7da73b1e
Cumulus实时媒体服务...
浏览量:22050
社区版块
存档分类
最新评论

MySQL Cluster开发环境快速部署(中文)

 
阅读更多

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


主要内容

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

1. 获取

这个不必多言吧,到MySQL网站上面下载就是了。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.inimy.cnf,内容如下:

config.ini

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

[mysqld]
ndbcluster
datadir=/home/user1/my_cluster/mysqld_data
basedir=/home/user1/mysql-cluster
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 的启动顺序是有要求的,如下:

  1. Management Node
  2. Data Nodes
  3. 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. 总结

  1. 有序启动:Management Node,Data Nodes,MySQL Server
  2. 配置项与各节点的对应
  3. 每个结点都单独启动
  4. Management Node 提供状态查看等多种功能

转载请注明来自柳大·Poechant的CSDN博客http://blog.CSDN.net/Poechant


分享到:
评论

相关推荐

    CenterOS 7.5下Mysql Cluster 7.6.12高可用集群搭建.docx

    MySQL Cluster是一种高可用性、分布式、内存中的数据库系统,它为关键任务应用程序提供低延迟和高吞吐量。在CentOS 7.5环境下搭建MySQL ...因此,在部署MySQL Cluster时,需根据业务需求和资源限制做出合理规划。

    MySQL集群快速指南-MySQL Cluster Quick Start Guide 翻译

    完成上述步骤后,可以通过提供的链接获取更多信息,例如MySQL Cluster 7.3的自动安装程序演示视频,以及MySQL Cluster评估指南等资源,进一步了解和优化MySQL集群的使用。 总之,MySQL集群快速指南提供了清晰的步骤...

    MySQLCluster.pdf

    - MySQL Cluster支持多种编程语言的API,便于不同语言开发者的应用开发。 - 集群的维护包括启动、停止和故障恢复等操作。 通过这些知识点,可以为部署和维护MySQL Cluster提供详实的理论和实践指导。

    MySQL数据库应用案例视频教程下载第19讲 MySQL Cluster.zip

    8. **适用场景**:讨论适合使用MySQL Cluster的业务环境,例如高并发、大数据量、对实时性要求高的应用。 9. **案例分析**:通过实际应用案例,展示MySQL Cluster在解决特定问题上的优势和实施过程。 通过本视频...

    mysql_cluster_guide

    2. **环境准备**:确保测试环境能够满足MySQL Cluster的最低要求,并预留足够的资源以应对可能的增长。 3. **测试计划**:制定详细的测试计划,包括基准测试、负载测试等,以全面评估MySQL Cluster的性能表现。 4. *...

    mysql_wp_cluster_quickstart

    从标题“mysql_wp_cluster_quickstart”以及提供的内容部分可以得知,文件主要针对的是快速搭建MySQL Cluster的基本指导。内容涉及到了下载安装软件、启动安装器、使用向导配置集群等步骤。 知识点详解: 1. 下载...

    clusterMysql.zip

    在这个场景下,我们有一个名为"clusterMysql.zip"的压缩包,它包含了一个基于SpringBoot和Redis的解决方案,用于实现在多个Tomcat服务器之间的session共享。这个方案通常应用于需要负载均衡的环境中,比如使用Nginx...

    MySQL Galera Cluster官方英文文档

    MySQL Galera Cluster是一种高可用性、高性能的...通过阅读这份官方英文文档,无论是开发人员、DBA还是系统管理员,都能深入理解MySQL Galera Cluster的工作原理,从而更好地设计、部署和维护高可用的数据库集群。

    Windows下mysql集群+linux下mysql集群

    虽然给定内容主要聚焦于 Windows 平台上的 MySQL 安装与配置,但构建跨平台的 MySQL 集群还需要了解 Linux 环境下的部署方法。下面简要介绍 Linux 下 MySQL 集群的配置步骤: **1. 安装 MySQL Server** - 在 ...

    MYSQL集群+HA高可用【MySQL性能调优】.pdf

    在实际部署中,MySQL Cluster的搭建需经过一系列精心规划的步骤,包括环境准备、软件安装、节点配置等。以下是一个基于CentOS 5/RHEL 5操作系统,使用MySQL版本5.1.22rc的部署示例: - **环境准备**:在三台主机上...

    MariaDB Galera Cluster

    MariaDB Galera Cluster是一种高可用性、高性能的数据库集群解决方案,主要用于MySQL和MariaDB数据库系统。它通过使用Galera库实现同步多主复制,确保数据在集群中的多个节点之间实时同步,从而提供无主式集群架构。...

    Linux系统-Linux中安装JDK/TOMCAT/MYSQL/linux中项目部署/集群搭建

    在Linux环境下进行Java应用开发和部署,通常需要安装Java开发工具包(JDK)、Web服务器(TOMCAT)以及数据库管理系统(MYSQL)。以下是针对这些组件在Linux系统中安装和配置的详细步骤。 ### 1. 安装JDK #### 1.1 卸载...

    mysql_pn_ha_innodb_cluster.pdf

    - **参考架构**: Oracle提供了多种参考架构,帮助用户根据实际场景选择合适的部署模式,如单数据中心、多数据中心以及云环境下的部署。 然而,需要注意的是,尽管InnoDB Cluster提供了强大的高可用性功能,但它的...

    CentOS7部署Galera Cluster

    本文将详细介绍如何在CentOS 7环境下部署MariaDB的Galera Cluster集群,以实现高可用性和数据一致性。 #### 二、Galera Cluster简介 Galera Cluster是一款基于同步复制的高级开源数据库集群解决方案,特别适合于...

    mysql 8.0官方英文文档

    MySQL 8.0 被视为一个开发系列版本,并不推荐用于生产环境。这意味着虽然该版本包含了大量新特性和技术改进,但在稳定性方面可能还存在一定的风险。因此,在决定是否将其部署到生产环境中时,用户需要仔细评估这些...

    k8s 创建mysql的 全套yaml文件

    在Kubernetes(k8s)集群中创建MySQL数据库服务,通常涉及到多个YAML文件的配置,这些文件共同定义了MySQL的部署、服务、持久卷和持久卷声明等组件。以下是对这一过程的详细阐述: 首先,`mysql-deployment.yaml`是...

    MySQL 5.5 参考手册(英文版)

    - **Connectors and APIs**:MySQL提供了多种语言的连接器,如Connector/J(Java)、Connector/C(C语言)、Connector/C++(C++)等,以及针对特定应用环境的APIs,如PHP、Python等,大大方便了不同开发环境下的...

    mysql操作手册

    它覆盖了选择合适的版本和分发方式、配置环境、解决常见问题等多个方面,确保用户能够顺利地部署和运行MySQL 8.0。 综上所述,《MySQL操作手册》是一份详尽的文档,不仅涵盖了MySQL 8.0的主要特性,还提供了丰富的...

Global site tag (gtag.js) - Google Analytics