最近在 学习MYSQL集群的配置,首先要了解什么集群,为什么要使用集群,以及安装集群的软件是什么和集群中的进程有哪些。
1.什么是集群?
集群是一组服务器提供相同的服务。
2.为什么要使用集群?
解决单点故障和数据的备份问题。
操作系统以及mysql配置文件的说明。
Linux系统:redhat6.5
安装集群软件: MySQL-Cluster-gpl-7.3.3-1.el6.x86_64.rpm-bundle.tar
服务器的角色:
实验要求:5台服务器,分别ip地址192.168.1.10做管理节点,192.168.1.20/192.168.1.30做数据节点使数据能够同时备份当其中任意一台服务器宕机后,对数据库进行操作,当宕机的服务器恢复后自动同步数据,192.168.1.40/192.168.1.50做sql节点当任意一台mysql节点故障后,都可以登陆数据库。
192.168.1.10(mgmd)
192.168.1.20(ndbd)
192.168.1.30 (ndbd)
192.168.1.40 (sql)
192.168.1.50 (sql)一。在所有服务器上安装提供集群服务的软件 mysql-cluster (.rpm 源码)
最简单是的PRM包,下面采用二进制包的方法进行安装
1.解压软件包。
[root@fanxh opt]# tar -xvf MySQL-Cluster-gpl-7.3.3-1.el6.x86_64.rpm-bundle.tar2.安装软件包,tar解压出来的是rpm包,直接安装就可以。
[root@fanxh opt]# rpm -Uvh MySQL-Cluster-*.rpm
3.查看软件包是否已安装。
[root@fanxh opt]# rpm -qa | grep -i mysql
MySQL-Cluster-shared-compat-gpl-7.3.3-1.el6.x86_64MySQL-Cluster-devel-gpl-7.3.3-1.el6.x86_64MySQL-Cluster-embedded-gpl-7.3.3-1.el6.x86_64perl-DBD-MySQL-4.013-3.el6.x86_64MySQL-Cluster-test-gpl-7.3.3-1.el6.x86_64MySQL-Cluster-server-gpl-7.3.3-1.el6.x86_64MySQL-Cluster-client-gpl-7.3.3-1.el6.x86_64MySQL-Cluster-shared-gpl-7.3.3-1.el6.x86_64
4.在192.168.1.10上配置管理节点。
管理节点运行的是管理进程,运行时加载自己的主配置文件,主配置文件需要自己写。
例如:配置文件为config.ini 配置文件的内容包括:
1 数据节点的公共配置[ndbd default] 2 指定管理节点[ndb_mgmd] 3 指定数据节点 [ndbd] 4 指定sql节点 [mysqld]
[root@fanxh ~]# vim /etc/config.ini
[ndbd default]NoOfReplicas=2 (表示数据节点的份数,有几个数据节点就写几)DataMemory=80M (表示数据缓存的大小)IndexMemory=18M (表示索引缓存的大小)[ndb_mgmd]nodeid=1 ( 用来设置当前主机在集群中的编号)hostname=192.168.1.10 (指定管理节点的IP地址)datadir=/var/log/mysql-cluster (指定把运行中的信息放在/var/log/mysql-cluster,这个文件夹 必须在系统中存在,如果没有创建该文件夹。)[ndbd]nodeid=2 (数据节点的编号)hostname=192.168.1.20 (数据节点的IP地址)datadir=/var/log/mysql-cluster/data (存储数据的位置)[ndbd]nodeid=3hostname=192.168.1.30datadir=/var/log/mysql-cluster/data[mysqld]nodeid=4hostname=192.168.1.40[mysqld]nodeid=5hostname=192.168.1.50
在192.168.1.10创建/var/log/mysql-cluster文件夹
[root@fanxh ~]# mkdir -p /var/log/mysql-cluster/
5.在192.168.1.20/192.168.1.30上配置数据节点
在192.168.1.20和192.168.1.30上 分别创建/var/log/mysql-cluster文件夹用来存储数据的位置
[root@fanxh ~]# mkdir -p /var/log/mysql-cluster/
创建主配置文件。 [root@fanxh ~]# vim /etc/my.cnf [mysqld] datadir=/var/log/mysql-cluster/data (指定数据库目录) ndb-connectstring=192.168.1.10 (指定连接管理集群的服务器IP) ndbcluster (表的存储引擎必须是ndbcluster) [mysql_cluster] ( 指定管理集群的机器) ndb-connectstring=192.168.1.10(指定谁来管理集群的服务器IP)6.在192.168.1.40/192.168.1.50上配置sql节点[root@fanxh ~]# vim /etc/my.cnf[mysqld]ndbclusterdefault-storage-engine=ndbcluster (指定默认的存储引擎)ndb-connectstring=192.168.1.10 (指定连接管理集群的服务器IP)[mysql_cluster]ndb-connectstring=192.168.1.10 (指定谁来管理集群的服务器IP)7.启动不同角色服务对应进程(有启动顺序,按照以下顺序进行启动)。
1 启动管理进程在192.168.1.10上。[root@fanxh ~]# ndb_mgmd -f /etc/config/init 启动mysql cluster服务MySQL Cluster Management Server mysql-5.6.14 ndb-7.3.3[root@fanxh ~]# netstat -anuptl | grep :1186 查看集群端口是否开启
tcp 0 0 0.0.0.0:1186 0.0.0.0:* LISTEN 4341/ndb_mgmd
tcp 0 0 127.0.0.1:38177 127.0.0.1:1186 ESTABLISHED 4341/ndb_mgmdtcp 0 0 127.0.0.1:1186 127.0.0.1:38177 ESTABLISHED 4341/ndb_mgmdtcp 0 0 192.168.1.10:1186 192.168.1.50:43075 ESTABLISHED 4341/ndb_mgmdtcp 0 0 192.168.1.10:1186 192.168.1.40:37459 ESTABLISHED 4341/ndb_mgmd[root@fanxh ~]# ndb_mgm 进入界面命令
-- NDB Cluster -- Management Client --
ndb_mgm> show 查看信息命令Connected to Management Server at: localhost:1186
Cluster Configuration---------------------[ndbd(NDB)] 2 node(s)id=2 (not connected, accepting connect from 192.168.1.20)id=3 (not connected, accepting connect from 192.168.1.30)[ndb_mgmd(MGM)] 1 node(s)id=1 @192.168.1.10 (mysql-5.6.14 ndb-7.3.3)[mysqld(API)] 2 node(s)id=4 (not connected, accepting connect from 192.168.1.40)id=5 (not connected, accepting connect from 192.168.1.50) 2 启动192.168.1.20/192.168.1.30上的数据进程 [root@fanxh ~]# ndbd 在192.168.1.20启动数据进程的命令2015-07-21 15:49:24 [ndbd] INFO -- Angel connected to '192.168.1.10:1186'
2015-07-21 15:49:24 [ndbd] INFO -- Angel allocated nodeid: 2 3 [root@localhost ~]# ndbd 在192.168.1.30启动数据进程的命令2015-07-21 10:16:16 [ndbd] INFO -- Angel connected to '192.168.1.10:1186'2015-07-21 10:16:16 [ndbd] INFO -- Angel allocated nodeid: 3 service mysql start3.启动完数据进程后在管理节点192.168.1.10上查看数据进程是否已经启动。
ndb_mgm> show
Cluster Configuration---------------------[ndbd(NDB)] 2 node(s)id=2 @192.168.1.20 (mysql-5.6.14 ndb-7.3.3, starting, Nodegroup: 0, *)id=3 @192.168.1.30 (mysql-5.6.14 ndb-7.3.3, starting, Nodegroup: 0)[ndb_mgmd(MGM)] 1 node(s)id=1 @192.168.1.10 (mysql-5.6.14 ndb-7.3.3)[mysqld(API)] 2 node(s)id=4 (not connected, accepting connect from 192.168.1.40)id=5 (not connected, accepting connect from 192.168.1.50)ndb_mgm> Node 2: Started (version 7.3.3)Node 3: Started (version 7.3.3) 4.在192.168.1.40/192.168.1.50启动mysql数据库服务。[root@fanxh ~]# service mysql startStarting MySQL SUCCESS!
5.启动完mysql数据库服务后在管理节点192.168.1.10上查看mysql进程是否已经启动。
ndb_mgm> show
Cluster Configuration---------------------[ndbd(NDB)] 2 node(s)id=2 @192.168.1.20 (mysql-5.6.14 ndb-7.3.3, Nodegroup: 0, *)id=3 @192.168.1.30 (mysql-5.6.14 ndb-7.3.3, Nodegroup: 0)[ndb_mgmd(MGM)] 1 node(s)id=1 @192.168.1.10 (mysql-5.6.14 ndb-7.3.3)[mysqld(API)] 2 node(s)id=4 @192.168.1.40 (mysql-5.6.14 ndb-7.3.3)id=5 @192.168.1.50 (mysql-5.6.14 ndb-7.3.3)8.客户端测试
1.访问节点的单点故障。在mysql 数据库服务上建表建库,进行查看。登陆mysql服务器192.168.1.40/192.168.1.50
[root@fanxh~]# cat /root/.mysql_secret
# The random password set for the root user at Mon Jul 6 04:54:27 2015 (local time): umdVqWxz[root@fanxh ~]# mysql -hlocalhost -uroot -pumdVqWxzmysql>set password for root@localhost=password("123")
mysql>quit
[root@fanxh ~]# mysql -hlocalhost -uroot -p123
Warning: Using a password on the command line interface can be insecure.Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 3Server version: 5.6.14-ndb-7.3.3-cluster-gpl MySQL Cluster Community Server (GPL)Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved .Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input stateme nt.查看存储引擎默认是不是dbcluster
mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+| Engine | Support | Comment | Transactions | XA | Savepoints |+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+| ndbcluster | DEFAULT | Clustered, fault-tolerant tables | YES | NO | NO |关闭192.168.1.50上的 mysql服务
[root@fanxh ~]# service mysql stop
查看192.168.1.10上的信息ndb_mgm> show
Cluster Configuration---------------------[ndbd(NDB)] 2 node(s)id=2 @192.168.1.20 (mysql-5.6.14 ndb-7.3.3, Nodegroup: 0, *)id=3 @192.168.1.30 (mysql-5.6.14 ndb-7.3.3, Nodegroup: 0)[ndb_mgmd(MGM)] 1 node(s)id=1 @192.168.1.10 (mysql-5.6.14 ndb-7.3.3)[mysqld(API)] 2 node(s)id=4 @192.168.1.40 (mysql-5.6.14 ndb-7.3.3)id=5 (not connected, accepting connect from 192.168.1.50)用192.168.1.40查看是否可以登陆数据库,如果可以登陆说明解决单点故障。
[root@localhost ~]# mysql -hlocalhost -uroot -p123
Warning: Using a password on the command line interface can be insecure.Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 2Server version: 5.6.14-ndb-7.3.3-cluster-gpl MySQL Cluster Community Server (GPL)Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>2.数据节点单点故障。(关闭1个数据服务,在表中进行插入,查看等一些操作,当另外一个恢复服务后,看能不能进行同步数据,如果可以说明就解决单点故障)验证数据节点单点故障的步骤:
1.关闭192.168.1.20的数据节点的服务。
[root@fanxh ~]# pkill -9 ndbd
2. 查看管理节点的192.168.1.20的状态。ndb_mgm> show
Cluster Configuration---------------------[ndbd(NDB)] 2 node(s)id=2 (not connected, accepting connect from 192.168.1.20)id=3 @192.168.1.30 (mysql-5.6.14 ndb-7.3.3, Nodegroup: 0, *)[ndb_mgmd(MGM)] 1 node(s)id=1 @192.168.1.10 (mysql-5.6.14 ndb-7.3.3)[mysqld(API)] 2 node(s)id=4 @192.168.1.40 (mysql-5.6.14 ndb-7.3.3)id=5 @192.168.1.50 (mysql-5.6.14 ndb-7.3.3) 3.在sql节点上查看数据库的信息,当192.168.1.20宕机后查看的信息是192.168.1.30的信息。在数据库上对表进行select ,insert into 等信息后,当192.168.1.30恢复后能不能同步数据,如果可以说明可以解决单点故障。