mysql cluster 安装配置方案

mysql cluster (mysql 集群)安装配置方案

 

1、准备node

一、准备服务器mysql

计划创建有5个节点的MySQL CLuster体系,须要用到5台服务器,可是咱们作实验时没有这么多机器,能够只用2台,我就是一台本机,一台虚拟机搭建了有5个节点的MySQL CLuster体系,将一个SQL节点一个数据节点一个SQL节点放在了一台服务器上(192.168.1.252),将另外一个SQL节点和一个数据节点放在了另一台服务器上(192.168.1.52)。linux

节点配置说明
节点 对应的IP和端口
管理节点(1个) 192.168.1.252
SQL节点 (2个) 192.168.1.252:3331
192.168.1.52:3331
数据节点 (2个) 192.168.1.252
192.168.1.52

二、准备软件包sql

如今的mysql提供了一个专门做集群的安装包,这样就不用一个个的下载所须要的工具了。我在网上找到了最新的并且下载比较快的资源,第一步先是下载,有200M左右。shell

cd /var/tmp

wget http://mysql.ntu.edu.tw/Downloads/MySQL-Cluster-7.1/  

mysql-cluster-gpl-7.1.9a-linux-i686-glibc23.tar.gz

2、安装数据库

一、数据节点和SQL节点vim

第一步 添加mysql用户和组,这是必需的。服务器

groupadd mysql

useradd -g mysql mysql

第二步 开始安装,下载的版本是免编译的,复制过来就能够用了。socket

cd /var/tmp

tar -C /usr/local-zxvf mysql-cluster-gpl-7.1.9a-linux-i686-glibc23.tar.gz

cd /usr/local

mv mysql-cluster-gpl-7.1.9a-linux-i686-glibc23.tar.gz mysql

第三步 在mysql修改目录权限,这也是必需的,否则第四步会报错的。工具

cd mysql

chown -R root .

chown -R mysql data

chgrp -R mysql .

第四步 安装初始的数据库表

scripts/mysql_install_db --user=mysql

第五步 设置mysql服务为开机自启动

cp support-files/mysql.server /etc/rc.d/init.d/mysqld

chmod +x /etc/rc.d/init.d/mysqld

chkconfig --add mysqld

第六步 启动mysql服务,若是报错请参考

service mysqld start

这六步,在252和52服务器上都执行一次,数据节点和SQL节点就算安装好了。

二、管理节点

管理节点的安装更简单,只要在252服务器上复制些文件出来就好了,虽然只有一步,便这一步在目前环境下(管理节点和SQL节点在同一台服务器上)也不是必需的。

cd mysql

cp bin/ndb_mgm*/usr/local/bin

cd /usr/local/bin

chmod +x ndb_mgm*

管理节点只要ndb_mgm和ndb_mgmd两个文件和一个配置文件便可,所以把这三个文件复制到那里,那里就是管理节点了。ndb_mgmd是mysql cluster管理服务器,ndb_mgm是客户端管理工具,等一下会用到它们的。到目前为止两个SQL节点两个数据节点和一个管理节点都安装完成了,可是还不能工做,得进行配置,把这几个节点联系在一块儿协同工做。

3、配置

一、数据节点和SQL节点

mysql服务启动时会默认加载/etc/my.cnf做为其配置文件,要将一个mysql服务器配置成一个数据节点和SQL节点也很是的简单,这是配置前的my.cnf的内容:

[client]

port    =3306

socket  =/tmp/mysql.sock

[mysqld]

basedir         =/usr/local/mysql/

datadir         =/usr/local/mysql/data

user            = mysql

log-error       =/var/lib/mysql/mysqld.err

 

只要在内容结尾加上4行就将这个mysql服务器变成了一个数据节点和SQL节点。

ndbcluster   #运行NDB存储引擎

#指定管理节点  以上两行声明其为SQL节点

ndb-connectstring=192.168.1.252  

[mysql_cluster]

#指定管理节点  以上两行声明其为数据节点

ndb-connectstring=192.168.1.252  

注意两台服务器都得这样配置。

二、管理节点

管理节点的配置复杂一点,在管理服务器252的/var/lib/mysql-cluster/目录中建立config.ini文件。

cd /var/lib

mkdir mysql-cluster

cd mysql-cluster

vim config.ini

在config.ini文件中添加如下内容:

[NDBD DEFAULT]

NoOfReplicas=1    #每一个数据节点的镜像数量

DataMemory=500M   #每一个数据节点中给数据分配的内存

IndexMemory=300M  #每一个数据节点中给索引分配的内存

[TCP DEFAULT]

portnumber=2202   #数据节点的默认链接端口

[NDB_MGMD]        #配置管理节点

hostname=192.168.1.252

datadir=/var/lib/mysql-cluster/  #管理节点数据(日志)目录

[NDBD]            #数据节点配置

hostname=192.168.1.252

datadir=/usr/local/mysql/data/   #数据节点目录

[NDBD]

hostname=192.168.1.52

datadir=/usr/local/mysql/data/

[MYSQLD]   #SQL节点目录

hostname=192.168.1.252

[MYSQLD]

hostname=192.168.1.52

[NDBD DEFAULT]:表示每一个数据节点的默认配置在每一个节点的[NDBD]中不用再写这些选项,只能有一个。
[NDB_MGMD]:表示管理节点的配置,只有一个。
[NDBD]:表示每一个数据节点的配置,能够有多个。
[MYSQLD]:表示SQL节点的配置,能够有多个,分别写上不一样SQL节点的IP地址,也能够什么都不写,只保留一个空节点,表示任意一个IP地址均可以进行访问,此节点的个数代表了能够用来链接数据节点的SQL节点总数。

4、启动

一、管理节点

mysql cluster 须要各个节点都 进行启动后才能够工做,节点的启动顺序为管理节点->数据节点->SQL节点。首先启动管理节点

cd /usr/local/bin

./ndb_mgmd -f /var/lib/mysql-cluster/config.ini

命令行中的ndb_mgmd是mysql cluster的管理服务器,后面的-f表示后面的参数是启动的参数配置文件。若是在启动后过了几天又添加了一个数据节点,这时修改了配置文件启动时就必须加上--initial参数,否则添加的节点不会做用在mysql cluster中。

./ndb_mgmd -f /var/lib/mysql-cluster/config.ini --initial

启动时可能会报个WARNING,如WARNING  -- at line 7: [TCP] portnumber is deprecated,这个不用管。能够正常工做的。

二、数据节点

安装后第一次启动数据节点时要加上--initial参数,其它时候不要加,除非是在备份、恢复或配置变化后重启时。

cd mysql/bin/ndbd --initial 

若是显示如下信息说明启动完成:

2010-12-31 12:48:03 [ndbd] INFO     -- Angel connected to '192.168.1.252:1186'
2010-12-31 12:48:03 [ndbd] INFO     -- Angel allocated nodeid: 3

三、SQL节点

service mysqld start

四、客户端管理

cd /usr/local/bin

./ndb_mgm

这时就进入到客户端,能够对mysql cluster进行各项操做,进入后会有ndb_mgm > 提示符出现,首先来查看各节点的链接状况,在ndb_mgm> 提示符下输入show:

ndb_mgm> show

ClusterConfiguration

---------------------

[ndbd(NDB)]     2 node(s)

id=2    @192.168.1.252  (mysql-5.1.51 ndb-7.1.9,Nodegroup:0,Master)

id=3    @192.168.1.52  (mysql-5.1.51 ndb-7.1.9,Nodegroup:1)

[ndb_mgmd(MGM)]1 node(s)

id=1    @192.168.1.252  (mysql-5.1.51 ndb-7.1.9)

[mysqld(API)]   2 node(s)

id=4    @192.168.1.252  (mysql-5.1.51 ndb-7.1.9)

id=5    @192.168.1.52  (mysql-5.1.51 ndb-7.1.9)

能够看到各个节点已经链接上了,至此,mysql cluster配置完成。

5、关闭

mysql cluster的关闭也很简单,只需在ndb_mgm> 提示符下输入 shutdown便可,这时会显示各节点的关闭信息,再输入exit便可退出ndb_mgm管理,回到shell中。虽然mysql cluster 关闭了,可是SQL节点的mysql服务并不会中止的。接下来就能够作各类试验了

相关文章
相关标签/搜索