5.1 MySQL Cluster 简介
请参考官方文档:http://dev.mysql.com/doc/refman/5.1/zh/ndbcluster.html
下面是官方的MySQL Cluster 的基本架构图:
5.2 MySQL Cluster环境搭建
搭建MySQL Cluster至少需要三个节点,一个管理节点来实现管理功能,一个SQL节点主机来实现MySQL server功能,一个ndb节点主机实现NDB Cluster的功能。
5.2.1 实验环境
主机名 |
IP地址 |
作用 |
MySQL-SQL-Node1 |
192.168.140.128 |
SQL 节点服务器 |
MySQL-Data-Node1 |
192.168.140.129 |
Data 节点服务器 |
MySQL-MGM-Node |
192.168.140.130 |
管理节点服务器 |
注意:如果你的实验环境是根据本文的设置,为了对MySQL Cluster的配置不冲突,请整理前面的实验环境,如下:
[root@MySQL-Proxy ~]# /etc/init.d/mysql-proxy stop
[root@MySQL-Slave ~]# /etc/init.d/mysqld stop
[root@MySQL-Master ~]# /etc/init.d/mysqld stop
5.2.2 部署安装环境
[root@MySQL-SQL-Node1 src]# wget
http://ftp.jaist.ac.jp/pub/mysql/Downloads/MySQL-Cluster-7.1/mysql-cluster-gpl-7.1.3.tar.gz
[root@MySQL-SQL-Node1 src]# chmod +x mysql-cluster-gpl-7.1.3.tar.gz
[root@MySQL-SQL-Node1 src]# scp mysql-cluster-gpl-7.1.3.tar.gz 192.168.140.129:/usr/local/src
[root@MySQL-SQL-Node1 src]# scp mysql-cluster-gpl-7.1.3.tar.gz 192.168.140.130:/usr/local/src
5.2.3 部署管理(MGM)节点
1> 安装MGM节点
[root@MySQL-MGM-Node ~]# cd /usr/local/src
[root@MySQL-MGM-Node src]# tar zxvf mysql-cluster-gpl-7.1.3.tar.gz
[root@MySQL-MGM-Node src]# cd mysql-cluster-gpl-7.1.3
[root@MySQL-MGM-Node mysql-cluster-gpl-7.1.3]# ./configure --prefix=/usr/local/mysqlcluster \
--with-charset=utf8 --with-collation=utf8_general_ci \
--with-client-ldflags=-all-static -with-mysqld-ldflags=-all-static \
--enable-assembler --with-extra-charsets=complex \
--enable-thread-safe-client --with-big-tables --with-readline \
--with-ssl --with-embedded-server --enable-local-infile \
--with-unix-socket-path=/usr/local/mysqlcluster/tmp/mysql.sock \
--sysconfdir=/usr/local/mysqlcluster/etc --without-debug \
--with-mysqld-user=mysql --with-plugins=max
[root@MySQL-MGM-Node mysql-cluster-gpl-7.1.3]# make && make install
2> 配置MGM节点
[root@MySQL-MGM-Node ~]# cd /usr/local/mysqlcluster/
[root@MySQL-MGM-Node mysqlcluster]# mkdir mysql-cluster
[root@MySQL-MGM-Node mysqlcluster]# vi mysql-cluster/config.ini
[NDBD DEFAULT]
NoOfReplicas= 1
DataMemory=50M
IndexMemory=10M
[NDB_MGMD]
id=1
HostName=192.168.140.130
DataDir=/usr/local/mysqlcluster/mysql-cluster
[NDBD]
id=2
HostName=192.168.140.129
DataDir=/usr/local/mysqlcluster/ndbdata
[MYSQLD]
id=3
HostName=192.168.140.128
3> 启动MGM节点
[root@MySQL-MGM-Node mysqlcluster]# libexec/ndb_mgmd -f
/usr/local/mysqlcluster/mysql-cluster/config.ini
5.2.4 部署NDBD节点
1> 安装NDBD节点
[root@MySQL-Data-Node1 ~]# cd /usr/local/src
[root@MySQL-Data-Node1 src]# tar zxvf mysql-cluster-gpl-7.1.3.tar.gz
[root@MySQL-Data-Node1 src]# cd mysql-cluster-gpl-7.1.3
[root@MySQL-Data-Node1 mysql-cluster-gpl-7.1.3]# ./configure --prefix=/usr/local/mysqlcluster \
--with-charset=utf8 --with-collation=utf8_general_ci \
--with-client-ldflags=-all-static -with-mysqld-ldflags=-all-static \
--enable-assembler --with-extra-charsets=complex \
--enable-thread-safe-client --with-big-tables --with-readline \
--with-ssl --with-embedded-server --enable-local-infile \
--with-unix-socket-path=/usr/local/mysqlcluster/tmp/mysql.sock \
--sysconfdir=/usr/local/mysqlcluster/etc --without-debug \
--with-mysqld-user=mysql --with-plugins=max
[root@MySQL-Data-Node1 mysql-cluster-gpl-7.1.3]# make && make install
2> 配置NDBD节点
[root@MySQL-Data-Node1 ~]# cd /usr/local/mysqlcluster/
[root@MySQL-Data-Node1 mysqlcluster]# mkdir etc ndbdata
[root@MySQL-Data-Node1 mysqlcluster]# vi etc/my.cnf
[mysqld]
basedir=/usr/local/mysqlcluster/
datadir=/usr/local/mysqlcluster/var
user=mysql
port=3306
socket=/usr/local/mysql/tmp/mysql.sock
ndbcluster
ndb-connectstring=192.168.140.130
[mysql_cluster]
ndb-connectstring=192.168.140.130
3> 启动NDBD节点
[root@MySQL-Data-Node1 mysqlcluster]# libexec/ndbd --initial
注意:
第一次启动需要加--initial参数进行初始化工作,在以后的启动中,千万不要加该参数,因为ndbd程序会清除之前建立的所有用于恢复的数据文件和日志文件。
5.2.5 部署SQL 节点
1> 安装SQL节点
[root@MySQL-SQL-Node1 ~]# cd /usr/local/src/
[root@MySQL-SQL-Node1 src]# tar zxvf mysql-cluster-gpl-7.1.3.tar.gz
[root@MySQL-SQL-Node1 src]# cd mysql-cluster-gpl-7.1.3
[root@MySQL-SQL-Node1 mysql-cluster-gpl-7.1.3]# ./configure --prefix=/usr/local/mysqlcluster \
--with-charset=utf8 --with-collation=utf8_general_ci \
--with-client-ldflags=-all-static -with-mysqld-ldflags=-all-static \
--enable-assembler --with-extra-charsets=complex \
--enable-thread-safe-client --with-big-tables --with-readline \
--with-ssl --with-embedded-server --enable-local-infile \
--with-unix-socket-path=/usr/local/mysqlcluster/tmp/mysql.sock \
--sysconfdir=/usr/local/mysqlcluster/etc --without-debug \
--with-mysqld-user=mysql --with-plugins=max
[root@MySQL-Data-Node1 mysql-cluster-gpl-7.1.3]# make && make install
2> 配置SQL节点
[root@MySQL-SQL-Node1 ~]# cd /usr/local/mysqlcluster/
[root@MySQL-SQL-Node1 mysqlcluster]# mkdir etc
[root@MySQL-SQL-Node1 mysqlcluster]# chown -R root:mysql .
[root@MySQL-SQL-Node1 mysqlcluster]# bin/mysql_install_db --user=mysql
[root@MySQL-SQL-Node1 mysqlcluster]# vi etc/my.cnf
[mysqld]
basedir=/usr/local/mysqlcluster/
datadir=/usr/local/mysqlcluster/var
user=mysql
port=3306
socket=/usr/local/mysql/tmpcluster/mysql.sock
ndbcluster
ndb-connectstring=192.168.140.130
[mysql_cluster]
ndb-connectstring=192.168.140.130
3> 启动SQL节点
[root@MySQL-SQL-Node1 mysqlcluster]# bin/mysqld_safe --user=mysql &
5.3 MySQL Cluster 测试
在管理节点上测试:
[root@MySQL-MGM-Node ~]# cd /usr/local/mysqlcluster/
[root@MySQL-MGM-Node mysqlcluster]# bin/ndb_mgm
-- NDB Cluster -- Management Client --
ndb_mgm> show
Connected to Management Server at: localhost:1186
Cluster Configuration
---------------------
[ndbd(NDB)]1 node(s)
id=2@192.168.140.129 (mysql-5.1.44 ndb-7.1.3, Nodegroup: 0, Master)
[ndb_mgmd(MGM)]1 node(s)
id=1@192.168.140.130 (mysql-5.1.44 ndb-7.1.3)
[mysqld(API)]1 node(s)
id=3@192.168.140.128 (mysql-5.1.44 ndb-7.1.3)