MySQL NDB 6.3.20集群安装配置 迈向高可靠性

数据库 MySQL 数据库运维
我们在这里要介绍的是MySQL NDB 6.3.20集群的安装与配置工作,这也是为了提升系统的整体可靠性而做的努力。

本文会先对MySQL集群稍作一点介绍,然后会提供一个安装过程。

介绍:

MySQL集群是一种在无共享架构系统里应用内存数据库集群的技术。这种无共享的架构可以使得系统使用非常便宜的并且是最小配置的硬件。

MySQL集群是一种分布式设计,目标是要达到没有任何单点故障点。因此,任何组成部分都应该拥有自己的内存和磁盘。任何共享存储方案如网络共享,网络文件系统和SAN设备是不推荐或不支持的。通过这种冗余设计,MySQL声称数据的可用度可以达到99。999%。

实际上,MySQL集群是把一个叫做NDB的内存集群存储引擎集成与标准的MySQL服务器集成。它包含一组计算机,每个都跑一个或者多个进程,这可能包括一个MySQL服务器,一个数据节点,一个管理服务器和一个专有的一个数据访问程序。它们之间的关系如下图所示:

安装

准备:

机器:    全部安装Red Hat Linux AS 5且关闭防火墙

软件:    mysql-cluster-gpl-6.3.20-linux-i686-glibc23.tar.gz

IP
Description
192.168.99.80
Management Node
192.168.99.88
SQL Node
192.168.99.89
Data Node
192.168.99.90
Data Node

四台机器分别分配如下IP及用途:

安装节点,四台机器,需要重复四次:

  1. [root@candyshop ~]#groupadd mysql  
  2. [root@candyshop ~]#useradd –g mysql mysql  
  3. [root@candyshop ~]#tar zxvf mysql-cluster-gpl-6.3.20-linux-i686-glibc23.tar.gz  
  4. [root@candyshop ~]#chown mysql:mysql mysql-cluster-gpl-6.3.20-linux-i686-glibc23  
  5. [root@candyshop ~]#mv mysql-cluster-gpl-6.3.20-linux-i686-glibc23 /usr/local/mysql  

上述命令先创建mysql组和mysql用户,并且把mysql分配到mysql组,然后将安装文件解压,把它放置到/usr/local/mysql目录。

配置

配置管理节点[192.168.99.80]:

创建以下文件/usr/local/mysql/cluster-conf/config.ini,并且放置如下内容:

  1. # Options affecting ndbd processes on all data nodes:  
  2. [ndbd default]  
  3. NoOfReplicas=2    # Number of replicas  
  4. DataMemory=80M    # How much memory to allocate for data storage  
  5. IndexMemory=18M   # How much memory to allocate for index storage  
  6.                   # For DataMemory and IndexMemory, we have used the  
  7.                   # default values. Since the "world" database takes up  
  8.                   # only about 500KB, this should be more than enough for  
  9.                   # this example Cluster setup.  
  10.    
  11. # Management process options:  
  12. [ndb_mgmd]  
  13. Id=1 
  14. Hostname=192.168.99.80           # Hostname or IP address of management node  
  15. Datadir=/usr/local/mysql/logs # Directory for management node log files  
  16.    
  17. # Options for data node "A":  
  18. [ndbd]  
  19. Id=2 
  20. Hostname=192.168.99.89           # Hostname or IP address  
  21. Datadir=/usr/local/mysql/ndbdata   # Directory for this data node's data files  
  22.    
  23. # Options for data node "B":  
  24. [ndbd]  
  25. Id=3 
  26. Hostname=192.168.99.90           # Hostname or IP address  
  27. Datadir=/usr/local/mysql/ndbdata   # Directory for this data node's data files  
  28.    
  29. # SQL node options:  
  30. [mysqld]  
  31. Id=4 
  32. Hostname=192.168.99.88           # Hostname or IP address  
  33.                                 # (additional mysqld connections can be  
  34.                                 # specified for this node for various  
  35.                                 # purposes such as running ndb_restore) 

在这个文件里,我们分别给四个节点分配了ID,这有利于更好的管理和区分各个节点。当然,要是不指定,MySQL也会动态分配一个。上述几个Datadir如果还不存在的需要手动创建。用mkdir –p命令即可。

配置数据节点[192.168.99.89, 192.168.99.90]:

创建/etc/my.cnf文件,内容如下

  1. # Options for mysqld process:  
  2. [mysqld]  
  3. Datadir=/usr/local/mysql/ndbdata  
  4. ndbcluster                      # run NDB storage engine  
  5. ndb-connectstring=192.168.99.80 # location of management server  
  6.    
  7. # Options for ndbd process:  
  8. [mysql_cluster]  
  9. ndb-connectstring=192.168.99.80 # location of management server 

配置SQL节点[192.168.99.88]

创建/etc/my.cnf文件,内容如下

  1. # Options for mysqld process:  
  2. [mysqld]  
  3. ndbcluster                      # run NDB storage engine  
  4. ndb-connectstring=192.168.99.80 # location of management server  
  5.    
  6. # Options for ndbd process:  
  7. [mysql_cluster]  
  8. ndb-connectstring=192.168.99.80 # location of management server  
  1. [root@server88 mysql]# ./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --ldata=/usr/local/mysql/data/  
  2. Installing MySQL system tables...  
  3. OK  
  4. Filling help tables...  
  5. OK  

到这里,所有配置已经完成了。

启动

启动管节点[192.168.99.80]:

  1. [root@candyshop mysql]# ./bin/ndb_mgmd -f cluster-conf/config.ini  
  2. [root@candyshop mysql]# ./bin/ndb_mgm  
  3. -- NDB Cluster -- Management Client --  
  4. ndb_mgm> show  
  5. Connected to Management Server at: 192.168.99.80:1186  
  6. Cluster Configuration  
  7. ---------------------  
  8. [ndbd(NDB)]     2 node(s)  
  9. id=2 (not connected, accepting connect from 192.168.99.89)  
  10. id=3 (not connected, accepting connect from 192.168.99.90)  
  11.    
  12. [ndb_mgmd(MGM)] 1 node(s)  
  13. id=1    @192.168.99.80 (mysql-5.1.30 ndb-6.3.20)  
  14.    
  15. [mysqld(API)]   1 node(s)  
  16. id=4 (not connected, accepting connect from 192.168.99.88)  

我们可以看到集群的状态都还没有启动,都是not connected状态。

  1. [root@candyshop mysql]# ./bin/ndb_mgmd -f cluster-conf/config.ini  
  2. [root@candyshop mysql]# ./bin/ndb_mgm  
  3. -- NDB Cluster -- Management Client --  
  4. ndb_mgm> show  
  5. Connected to Management Server at: 192.168.99.80:1186  
  6. Cluster Configuration  
  7. ---------------------  
  8. [ndbd(NDB)]     2 node(s)  
  9. id=2 (not connected, accepting connect from 192.168.99.89)  
  10. id=3 (not connected, accepting connect from 192.168.99.90)  
  11.    
  12. [ndb_mgmd(MGM)] 1 node(s)  
  13. id=1    @192.168.99.80 (mysql-5.1.30 ndb-6.3.20)  
  14.    
  15. [mysqld(API)]   1 node(s)  
  16. id=4 (not connected, accepting connect from 192.168.99.88)  

启动数据节点[192.168.99.89, 192.168.99.90]:

  1. [root@server89 ~]#cd /usr/local/mysql  
  2. [root@server89 mysql]#./bin/ndbd  

启动SQL节点[192.168.99.88]:

  1. [root@server88 mysql]# ./bin/mysqld_safe &  

至此,所有节点已经启动完成,让我们来查看系统状态:

  1. ndb_mgm> show  
  2. Connected to Management Server at: localhost:1186  
  3. Cluster Configuration  
  4. ---------------------  
  5. [ndbd(NDB)]     2 node(s)  
  6. id=2    @192.168.99.89 (mysql-5.1.30 ndb-6.3.20, Nodegroup: 0, Master)  
  7. id=3    @192.168.99.90 (mysql-5.1.30 ndb-6.3.20, Nodegroup: 0)  
  8.    
  9. [ndb_mgmd(MGM)] 1 node(s)  
  10. id=1    @192.168.99.80 (mysql-5.1.30 ndb-6.3.20)  
  11.    
  12. [mysqld(API)]   1 node(s)  
  13. id=4    @192.168.99.88 (mysql-5.1.30 ndb-6.3.20)  

至此,安装已经结束

原文链接:http://ginge.javaeye.com/blog/320205

【编辑推荐】 

  1. MySQL数据库集群进行正确配置步骤
  2. MySQL 集群在Server1与Server2上如何安装MySQL
  3. MySQL集群配置
  4. MySQL集群自动安装脚本
  5. MySQL触发器如何正确使用

 

责任编辑:彭凡 来源: Javaeye博客
相关推荐

2010-10-22 09:51:00

Hyper-V

2013-10-12 10:19:44

虚拟化可靠性

2013-10-14 16:47:06

虚拟化容错服务器

2014-12-04 14:03:32

SUSELinux

2014-02-13 10:30:13

云计算迪普科技DPX19000

2010-07-28 18:58:54

东海证券负载均衡Array Netwo

2010-04-26 10:18:50

2012-08-07 14:44:13

布线数据中心布线

2013-05-28 15:31:57

华为华为通信铁路通信

2011-01-04 12:36:34

Array Netwo负载均衡

2010-04-30 14:32:48

2017-03-28 16:06:42

StratusVMware虚拟化

2010-12-28 19:50:21

可靠性产品可靠性

2009-11-09 17:40:33

WCF配置可靠性

2023-05-15 08:00:00

2011-05-25 19:31:07

Stratus信息化

2010-12-28 20:16:24

2009-04-08 10:23:00

软交换网络可靠

2019-08-30 12:10:05

磁盘数据可靠性RAID

2015-05-27 14:25:08

HDFS HA分布式存储系统
点赞
收藏

51CTO技术栈公众号