上次的博文中我们介绍了一下集群的相关概念,今天的博文我们介绍一下MySQL集群的相关内容。

  1、MySQL集群简介

  MySQL群集技术在分布式系统中为MySQL数据提供了冗余特性,增强了安全性,使得单个MySQL服务器故障不会对系统产生巨大的负面效应,系统的稳定性得到保障。

  MySQL群集需要有一组计算机,每台计算机的角色可能是不一样的。MySQL群集中有三种节点:管理节点、数据节点和SQL节点。群集中的某计算机可能是某一种节点,也可能是两种或三种节点的集合。这三种节点只是在逻辑上的划分,所以它们不一定和物理计算机是一一对应的关系。

  管理节点(也可以称管理服务器)主要负责管理数据节点和SQL节点,还有群集配置文件和群集日志文件。它监控其他节点的工作状态,能够启动、关闭或重启某个节点。其他节点从管理节点检索配置数据,当数据节点有新事件时就把事件信息发送给管理节点并写入群集日志。

  数据节点用于存储数据。

  SQL节点跟一般的MySQL服务器是一样的,我们可以通过它进行SQL操作。

  下图中画出了三种群集节点及应用程序间的关系:

Mysql集群技术之二:Mysql集群环境的搭建

  2、MySQL集群安装配置

  下载MySQL集群:http://dev.mysql.com/downloads/cluster/

  mysql-cluster-gpl-7.3.5-winx64.zip:

  http://dev.mysql.com/Downloads/MySQL-Cluster-7.3/mysql-cluster-gpl-7.3.5-winx64.zip

  mysql-cluster-gpl-7.3.5-win32.zip:

  http://dev.mysql.com/Downloads/MySQL-Cluster-7.3/mysql-cluster-gpl-7.3.5-win32.zip

  1)、MySQL简介

  首先找三台电脑,或者是开三个虚拟机,管理节点部署在一台机子上,其他两台每台都部署一个数据节点和一个SQL节点。这里以两台机子举例,其中一台(IP为192.168.24.16)部署管理节点、数据节点和SQL节点,另一台(IP为192.168.24.43)部署数据节点和SQL节点。

  实际应用中,不要将管理节点跟数据节点部署到一台机子上,因为如果数据节点宕机会导致管理节点不可用,同时整个MySQL群集也就都不可用了。所以一个MySQL群集理想情况下至少有三台服务器,将管理节点单独放到一台服务器上。这里以两台举例,只是为了说明三种节点的配置启动方法。

  2)、配置管理节点

  1、在IP为192.168.24.16的主机的C盘中新建文件夹mysql,然后在此文件夹下新建子目录bin和mysql-cluster,再将安装包中的bin目录下的ndb_mgm.exe和ndb_mgmd.exe拷贝到C:\mysql\bin下。在目录C:\mysql\bin下新建cluster-logs目录、config.ini文件和my.ini文件。

  2、config.ini文件内容如下:

C++代码
  1. [ndbd default]     
  2. # Options affecting ndbd processes on all data nodes:     
  3. # Number of replicas    
  4. NoOfReplicas=2     
  5. DataDir=c:/mysqlcluster/datanode/mysql/bin/cluster-data         
  6. # Directory for each data node's data files                                 
  7. # Memory allocated to data storage                                                      
  8. DataMemory=80M    
  9. # Memory allocated to index storage        
  10. IndexMemory=18M                          
  11. # For DataMemory and IndexMemory, we have used the                       
  12. # default values.    
  13.     
  14. [ndb_mgmd]     
  15. # Management process options:    
  16. # Hostname or IP address of management node      
  17. HostName=192.168.24.16                 
  18. # Directory for management node log files     
  19. DataDir=C:/mysql/bin/cluster-logs    
  20.     
  21. [ndbd]     
  22. # Options for data node "A":                                    
  23. # (one [ndbd] section per data node)     
  24. # Hostname or IP address    
  25. HostName=192.168.24.16            
  26.     
  27. [ndbd]     
  28. # Options for data node "B":     
  29. # Hostname or IP address    
  30. HostName=192.168.24.43              
  31.     
  32. [mysqld]     
  33. # SQL node options:     
  34. # Hostname or IP address    
  35. HostName=192.168.24.16         
  36.     
  37. [mysqld]     
  38. # SQL node options:     
  39. # Hostname or IP address    
  40. HostName=192.168.24.43    

  3、my.ini中的内容如下:

  [plain] view plain copy print?在CODE上查看代码片派生到我的代码片

  [mysql_cluster]

  # Options for management node process

  config-file=C:/mysql/bin/config.ini

  3)、配置数据节点

  1、在IP为192.168.24.16的主机中新建文件夹C:\mysqlcluster\datanode\mysql,然后在此文件夹中继续新建子目录bin和cluster-data,bin下再建一个子目录也叫cluster-data。

  2、将安装包data目录下的所有文件拷贝到C:\mysqlcluster\datanode\mysql\cluster-data下

  3、将安装包中bin目录下的ndbd.exe拷贝到C:\mysqlcluster\datanode\mysql\bin下,并在C:\mysqlcluster\datanode\mysql中新建my.ini文件,文件内容为:

C++代码
  1. [mysql_cluster]    
  2. # Optionsfor data node process:    
  3. #location of management server    
  4. ndb-connectstring=192.168.24.16   

  注:因为数据节点的配置是一样的,所以我们可以直接将192.168.24.16主机中的文件夹C:\mysqlcluster拷贝到192.168.24.43主机的C盘下。

  4)、配置SQL节点

  1、在192.168.24.16主机的C:\mysqlcluster下新建子目录sqlnode,在C:\mysqlcluster\sqlnode下新建子目录mysql,将安装包文件解压到mysql目录下,然后在C:\mysqlcluster\sqlnode\mysql下新建my.ini文件,文件内容为:

C++代码
  1. [mysqld]     
  2. # Options for mysqld process:     
  3. # run NDB storage engine     
  4. ndbcluster                           
  5. # location of management server     
  6. ndb-connectstring=192.168.24.16    

  2、将my-default.ini 文件删除或更名为my-default.ini.bak

  注:因为SQL节点的配置也是一样的,所以我们可以直接将192.168.24.16主机中的文件夹C:\mysqlcluster\sqlnode文件夹整个拷贝到192.168.24.43主机的C盘下。

  3、启动MySQL Cluster

  1)简介

  在启动MySQL Cluster之前,首先要做的是保证每个SQL节点上的MySQL服务能够启动成功,并为每个SQL节点进行相关权限的分配以保证能够远程登录访问。然后依次启动三种节点。三种节点服务启动时,一定要按照先启动管理节点,后启动数据节点,再启动SQL节点的顺序进行。

  2)、启动MySQL服务

  1、进入C:\mysqlcluster\sqlnode\mysql\bin目录下,使用mysqld –install安装MySQL服务

  2、 使用net start mysql命令启动MySQL服务

Mysql集群技术之二:Mysql集群环境的搭建

  3)配置MySQL远程连接

  1、 进入C:\mysqlcluster\sqlnode\mysql\bin目录下,使用mysql –uroot –p,然后输入密码,设置root用户密码。

Mysql集群技术之二:Mysql集群环境的搭建

  注:第一次输入的密码,即默认设置为root密码。

  2、 切换到mysql数据库,输入以下命令,为root用户分配远程连接的相关权限

C++代码
  1. GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;    

Mysql集群技术之二:Mysql集群环境的搭建

  4)、启动管理节点

  1、在192.168.24.16主机中打开命令行窗口,切到C:\mysql\bin目录,输入:

C++代码
  1. ndb_mgmd -f config.ini --configdir=C:\mysql\mysql-cluster    

  回车,管理节点服务就启动了,命令行上可能没有任何提示信息,可以打开C:\mysql\bin\cluster-logs\ndb_1_cluster.log日志文件查看启动信息。

  注意,此命令行窗口不能关闭,除非你想停止服务。

  2、也可以将其做成服务,在命令行中输入:

C++代码
  1. ndb_mgmd --install=ndb_mgmd -f config.ini --configdir=C:\mysql\mysql-cluster    

  5)、启动数据节点

  1、在192.168.24.16主机中打开新命令行窗口,切到C:\mysqlcluster\datanode\mysql\bin,输入:

C++代码
  1. ndbd   

  2、也可以将其做成服务,在命令行中输入:

C++代码
  1. ndbd --install=ndbd   

  3、以相同的方法在其他数据节点,即192.168.24.43中启动数据节点服务。

  4、在192.168.24.16主机中打开新命令行窗口,切到目录C:\mysql\bin,输入:

C++代码
  1. ndb_mgm   

  回车,然后再输入:

C++代码
  1. ALL STATUS    

  回车,就可以查看数据节点的连接信息了。

  6)、启动SQL节点

  1、在192.168.24.16主机中打开新命令行窗口,切到C:\mysqlcluster\sqlnode\mysql\bin,输入:

C++代码
  1. mysqld --console    

  回车,SQL节点启动。

  2、也可以将其做成服务,输入:

C++代码
  1. mysqld -install mysql  

  3、以相同的方法在其他SQL节点,即192.168.24.43中启动SQL节点。

  4、想要查看SQL节点的启动情况可以在192.168.1.10主机中同样打开新命令行,输入:

C++代码
  1. ndb_mgm   

  回车,再输入:

C++代码
  1. SHOW  

  回车,就可以看到SQL节点的连接情况了。

  4、测试MySQL Cluster

  1)、在任一SQL结点,即192.168.24.16主机上新创建一个数据库myDB,可以看到其他SQL结点,即192.168.24.43均创建了一个MyDB数据库

  2)、在任一SQL结点,即192.168.24.16主机上的myDB中使用

C++代码
  1. create table student (id int(2)) engine=ndbcluster;    

  新建一个student表,可以看到其他SQL结点,即192.168.24.43均在myDB数据库中创建了一个student表

  3)、在任一SQL结点,即192.168.24.16主机上的myDB中的student表插入几条数据之后,可以看到其他SQL结点,即192.168.24.43均作了相关的变化

  注:与没有使用 Cluster的MySQL相比,在MySQL Cluster内操作数据的方式没有太大的区别。执行这类操作时应记住两点:

  1、表必须用ENGINE=NDB或ENGINE=NDBCLUSTER选项创建,或用ALTER TABLE选项更改,以使用NDB Cluster存储引擎在 Cluster内复制它们。如果使用mysqldump的输出从已有数据库导入表,可在文本编辑器中打开SQL脚本,并将该选项添加到任何表创建语句,或用这类选项之一替换任何已有的ENGINE(或TYPE)选项。

  2、另外还请记住,每个NDB表必须有一个主键。如果在创建表时用户未定义主键,NDB Cluster存储引擎将自动生成隐含的主键。(注释:该隐含 键也将占用空间,就像任何其他的表索引一样。由于没有足够的内存来容纳这些自动创建的键,出现问题并不罕见)。

  到此为止关于MySQL集群的搭建就讲解完毕了,但是单纯的按照这样搭建还有一个缺陷,什么缺陷呢?咱们下次讲解,敬请期待!

除非特别注明,鸡啄米文章均为原创
转载请标明本文地址:http://www.jizhuomi.com/software/526.html
2016年3月10日
作者:鸡啄米 分类:软件开发 浏览: 评论:0