Centos6.5下安装Mysql集群

前端之家收集整理的这篇文章主要介绍了Centos6.5下安装Mysql集群前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

安装要求:
安装环境:Centos6.5
安装方式:源码安装
软件名称MysqL-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
软件安装位置:/usr/local/MysqL
数据存放位置:/var/MysqL/data
日志存放位置:/var/MysqL/logs

集群设计:
首先设计集群的安装分配方式,至少需要三台服务器,
sql节点和数据节点可以放在同一台服务器上,服务器分配如下:
管理节点:192.168.147.129
sql节点和数据节点1:192.168.147.130
sql节点和数据节点2:192.168.147.132
目前此设计存在的问题是管理节点是单点的,129管理节点服务器挂掉后整个集群就会瘫痪。

检查安装的MysqL
检查系统中已经安装过的MysqL信息,如果有卸载之:
[root@wjx/]#rpm -qa | grep MysqL #查看MysqL信息
[root@wjx/]# service MysqL status #查看MysqL服务的状态
[root@wjx/]# /etc/init.d/MysqLd stop #关闭目前的MysqL服务
[root@wjx/]# ps -ef | grep MysqL #检验MysqL是否已经关闭如果没关闭,执行kill -9 端口号
[root@wjx/]#rpm -e --allmatches --nodeps MysqL MysqL-server #执行删除或者用如下口令
[root@wjx/]#yun remove MysqL MysqL-*
[root@wjx/]#rm -rf /var/lib/MysqL #删除MysqL的安装目录

管理节点的安装:
安装管理节点在(192.168.147.129)上
[root@wjx/]# groupadd MysqL

[root@wjx/]# useradd MysqL -g MysqL
[root@wjx/]# cd /usr/local
[root@wjxlocal]# tar -zxvf MysqL-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
[root@wjxlocal]# mv MysqL-cluster-gpl-7.2.26-linux2.6-x86_64 MysqL
[root@wjxlocal]# chown -R MysqL:MysqL MysqL

[root@wjxlocal]# cd MysqL
[root@wjxMysqL]# scripts/MysqL_install_db --user=MysqL

配置管理节点
[root@wjx~]# mkdir /var/lib/MysqL-cluster

[root@wjx~]# cd /var/lib/MysqL-cluster
[root@wjxMysqL-cluster]# vi + /var/lib/MysqL-cluster/config.ini

在config.ini中添加如下内容
[NDBD DEFAULT]

NoOfReplicas=1
[TCP DEFAULT]
portnumber=3306

[NDB_MGMD]
#设置管理节点服务器
HostName=192.168.147.129
DataDir=/var/MysqL/data

[NDBD]
#设置存储节点服务器(NDB节点)
HostName=192.168.147.130
DataDir=/var/MysqL/data

[NDBD]
#第二个NDB节点
HostName=192.168.147.132
DataDir=/var/MysqL/data

[MysqLD]
#设置sql节点服务器
HostName=192.168.147.130
[MysqLD]
#第二个sql节点
HostName=192.168.147.132

管理节点启动
[root@wjx~]# /usr/local/MysqL/bin/ndb_mgmd -f /var/lib/MysqL-cluster/config.ini#启动节点显示如下内容
MysqL Cluster Management Server MysqL-5.5.53 ndb-7.2.26
2016-10-22 00:40:32 [MgmtSrvr] INFO -- The default config directory '/usr/local/MysqL/MysqL-cluster' does not exist. Trying to create it...
2016-10-22 00:40:32 [MgmtSrvr] INFO -- Sucessfully created config directory
2016-10-22 00:40:32 [MgmtSrvr] WARNING -- at line 4: [TCP] portnumber is deprecated

[root@wjx~]# mkdir /var/MysqL/logs
[root@wjx~]# netstat -lntpu
[root@wjxMysqL-cluster]# /usr/local/MysqL/bin/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.147.130)
id=3 (not connected,accepting connect from 192.168.147.132)
[ndb_mgmd(MGM)] 1 node(s)

id=1 @192.168.147.129 (MysqL-5.5.53 ndb-7.2.26)

[MysqLd(API)] 2 node(s)
id=4 (not connected,accepting connect from 192.168.147.130)
id=5 (not connected,accepting connect from 192.168.147.132)

ndb_mgm>
管理节点的关闭:
[root@wjx/]# /usr/local/MysqL/bin/ndb_mgm -e shutdown

数据节点的安装
数据节点1: 192.168.147.130
数据节点2: 192.168.147.132

[root@test/]# groupadd MysqL
[root@test/]# useradd MysqL -g MysqL
[root@test /]# cd /usr/local
[root@test local]# tar -zxvf MysqL-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
[root@test local]# mv MysqL-cluster-gpl-7.2.26-linux2.6-x86_64 MysqL
[root@test local]# chown -R MysqL:MysqL MysqL
[root@test local]# cd MysqL
[root@test MysqL]# scripts/MysqL_install_db --user=MysqL
[root@test MysqL]# cp support-files/my-medium.cnf /etc/my.cnf
[root@test MysqL]# cp support-files/MysqL.server /etc/init.d/MysqLd

配置数据节点
[root@test MysqL]# mkdir -p /var/MysqL/data
[root@test MysqL]# mkdir /var/MysqL/logs
[root@test MysqL]# vi /etc/my.cnf #添加如下内容

[MysqLD]
ndbcluster
ndb-connectstring=192.168.147.129
[MysqL_CLUSTER]
ndb-connectstring=192.168.147.129
[NDB_MGM]
connect-string=192.168.147.129

数据节点的启动
[root@test MysqL]# /usr/local/MysqL/bin/ndbd --initial #只是在第一次启动或在备份/恢复或配置变化后重启ndbd时,才加�Cinitial参数!
第一次启动如下:

2016-10-2213:43:53 [ndbd] INFO -- Angel connected to '192.168.147.129:1186'
2016-10-2213:43:53 [ndbd] INFO -- Angel allocated nodeid: 2
[root@localhost MysqL]# /usr/local/MysqL/bin/ndbd #正常启动方式
数据节点的关闭

[root@test /]# /etc/rc.d/init.d/MysqLd stop #或者
[root@test MysqL]# /etc/init.d/MysqL stop
Shutting down MysqL.. SUCCESS!

/usr/local/MysqL/bin/MysqLadmin -uroot shutdown

sql节点的安装
sql节点和存储节点(NDB节点)安装相同,都执行以下操作;

sql节点1: 192.168.147.130
sql节点2: 192.168.147.132
[root@test /]# groupadd MysqL
[root@test /]# useradd MysqL -g MysqL
[root@test /]# cd /usr/local
[root@test local]# tar -zxvf MysqL-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
[root@test local]# mv MysqL-cluster-gpl-7.2.26-linux2.6-x86_64 MysqL
[root@test local]# chown -R MysqL:MysqL MysqL
[root@test local]# cd MysqL
[root@test MysqL]# scripts/MysqL_install_db --user=MysqL
[root@test MysqL]# cp support-files/my-medium.cnf /etc/my.cnf
[root@test MysqL]# cp support-files/MysqL.server /etc/init.d/MysqLd

sql节点配置
[root@test MysqL]# mkdir -p /var/MysqL/data #创建存储数据的文件
[root@test MysqL]# mkdir /var/MysqL/logs #创建存储日志的文件
[root@test MysqL]# vi /usr/local/MysqL/my.cnf #修改配置文件

在my.cnf中追加以下内容
[MysqLD]

ndbcluster
ndb-connectstring=192.168.147.129
[MysqL_CLUSTER]
ndb-connectstring=192.168.147.129
[NDB_MGM]
connect-string=192.168.147.129
数据节点和sql节点安装在同一台服务器时3306端口会冲突导致数据库服务启动不了只需要在my.cnf中将端口号改了即可,如下

[client]
#password = your_password
port = 3308
socket = /tmp/MysqL.sock
# Here follows entries for some specific programs
# The MysqL server
[MysqLd]
port = 3308
socket = /tmp/MysqL.sock
skip-external-locking


sql节点启动
[root@test MysqL]# service MysqLd start

Starting MysqL.. SUCCESS!

sql节点关闭
[root@test MysqL]# /usr/local/MysqL/bin/MysqLadmin -uroot shutdown#最直接的方式
[root@test MysqL]# service MysqLd stop
[root@test MysqL]# /etc/init.d/MysqLd stop

#至此数据节点和sql节点安装配置完毕只需要在.130和.132两台服务器上启动数据节点服务和MysqL服务即可,启动后正常显示如下

[root@test ~]# /usr/local/MysqL/bin/ndbd

2016-10-22 15:17:58 [ndbd] INFO -- Angel connected to '192.168.147.129:1186'

2016-10-22 15:17:58 [ndbd] INFO -- Angel allocated nodeid: 3

[root@test ~]# service MysqLd start

Starting MysqL SUCCESS!

功能测试
在管理节点(192.168.147.129)上查看服务状态

[root@wjx~]# /usr/local/MysqL/bin/ndb_mgmd -f /var/lib/MysqL-cluster/config.ini

MysqL Cluster Management Server MysqL-5.5.53 ndb-7.2.26

[root@wjx~]# /usr/local/MysqL/bin/ndb_mgm

-- NDB Cluster -- Management Client --

ndb_mgm> show

Cluster Configuration

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

[ndbd(NDB)] 2 node(s)

id=2 @192.168.147.130 (MysqL-5.5.53 ndb-7.2.26,Nodegroup: 0,*)

id=3 @192.168.147.132 (MysqL-5.5.53 ndb-7.2.26,no nodegroup)

[ndb_mgmd(MGM)] 1 node(s)

id=1 @192.168.147.129 (MysqL-5.5.53 ndb-7.2.26)

[MysqLd(API)] 2 node(s)

id=4 @192.168.147.130 (MysqL-5.5.53 ndb-7.2.26)

id=5 @192.168.147.132 (MysqL-5.5.53 ndb-7.2.26)
可以看到这里的数据节点、管理节点、sql节点都是正常的。

注意
1.
在建表的时候一定要用ENGINE=NDB或ENGINE=NDBCLUSTER指定使用NDB集群存储引擎,或用ALTER TABLE选项更改表的存储引擎。
2.NDB表必须有一个主键,因此创建表的时候必须定义主键,否则NDB存储引擎将自动生成隐含的主键
3.sql节点的用户权限表仍然采用MYISAM存储引擎保存的,所以在一个sql节点创建的MysqL用户只能访问这个节点,如果要用同样的用户访问别的sql节点,需要在对应的sql节点追加用户。虽然在MysqL Cluster7.2版本开始提供了”用户权限共享”。

数据同步测试
在一个数据节点上进行相关数据库的创建,然后到另外一个数据节点上看看数据是否同步。
1步:sql节点1(192.168.147.130)上增加数据:
[root@test MysqL]# /etc/rc.d/init.d/MysqLd status #检验MysqL是否运行
[root@test MysqL]# /etc/rc.d/init.d/MysqLd start #启动MysqL
[root@test MysqL]# /usr/local/MysqL/bin/MysqL -u root -p

Enter password:
MysqL> show databases;
MysqL> create database testdb2;
MysqL> use testdb2;
MysqL> CREATE TABLE td_test2 (i INT) ENGINE=NDB; #这里必须指定数据库表的引擎为NDBCLUSTER,与配置文件中的名称相同
MysqL> INSERT INTO td_test2() VALUES (1);
MysqL> INSERT INTO td_test2() VALUES (152);
MysqL> SELECT * FROM td_test2;
2步:进入到sql节点2(192.168.147.132)上查看数据
MysqL> use testdb2;

Database changed
MysqL> SELECT * FROM td_test2;
+------+
| i |
+------+
| 152|
| 1 |
+------+

2 rows in set (0.01 sec)
3步:反向测试,sql节点2(192.168.147.132)上增加数据:
MysqL> create database bb;
MysqL> use bb;

MysqL> CREATE TABLE td_test3 (i INT) ENGINE=NDB;
MysqL> INSERT INTO td_test3 () VALUES (98);
MysqL> SELECT * FROM td_test3;
第四步:sql节点1(192.168.15.232)上查看数据:
Database changed
MysqL> SELECT * FROM td_test3;
+------+
| i |
| 98 |
1 row in set (0.00 sec)

关闭集群

关闭管理节点,然后关闭sql节点和数据节点。

集群启动操作顺序

要再次启动集群,按照以下顺序执行:

管理节点->数据节点�C> sql节点注意:此次启动数据节点时不要加”�Cinitial”参数。

启动中的常见错误

错误提示
Can't connect to local MysqL server through socket '/tmp/MysqL.sock' (2)
解决办法1(端口占用)netstat -anp |grep 3306
kill -9 进程号
解决办法1(权限问题)[root@localhost MysqL]# chown -R MysqL:MysqL /var/MysqL //修改自定义文件夹的访问权限

修改root用户空密码语句:

use MysqL;

update user setPassword=password('root') where User='root';

set PASSWORD FOR'root'@'localhost' = PASSWORD('root');
赋予root用户所有权限:
grant allprivileges on *.* to 'root'@'%'identified by 'root' with grant option;

权限即刻生效:
flush privileges;

猜你在找的CentOS相关文章