cent os + MySQL Cluster 7.3.7 集群配置

阅读更多
一、环境:
CentOS6.3(64位) + MySQL Cluster 7.3.7,规划5台虚拟机器,1G内存,分工如下:
MGM:10.10.10.41(管理节点)
NDBD1:10.10.10.42(数据节点1)
NDBD2:10.10.10.43(数据节点2)
SQL1:10.10.10.44(sql节点1)
SQL2:10.10.10.45(sql节点2)


二、准备:
安装包主要有三种类型:1:rpm安装包;2:预编译二进制安装包; 3:源码包。
这里选择第二种安装包“预编译二进制安装包”,它只需要解压即可。
先官网下载页面 http://dev.mysql.com/downloads/cluster/,选择 Linux - Generic 下面的 mysql-cluster-gpl-7.3.7-linux-glibc2.5-x86_64.tar.gz 这个安装包!
由于浏览器兼容的问题,我在访问这个页面时,下拉框选择之后事件触发没有生效,换个浏览器即可,找不到的可以直接选用以下链接 http://dev.mysql.com/downloads/file.php?id=454198

三、预处理:
清除MySQL旧版本:
首先使用如下命令来清理之前操作系统自带的MySQL安装:
yum -y remove mysq

然后使用如下命令:
rpm -qa | grep mysql*

检查是否还有残留的mysql包,如果存在如下类似的效果:
[root@localhost src]# rpm -qa | grep mysql*
mysql-libs-5.1.61-4.el6.i686
apr-util-mysql-1.3.9-3.el6_0.1.i686

则使用如下的命令格式将其删除:
rpm  -e  --nodeps  mysql-libs-5.1.61-4.el6.i686
rpm  -e  --nodeps  apr-util-mysql-1.3.9-3.el6_0.1.i686


四、mysql安装:
本步骤是所有机器都需要的操作:
1:将前面我们下载下来的压缩包mysql-cluster-gpl-7.3.7-linux-glibc2.5-x86_64.tar.gz上传到cent os指定目录下(或者直接使用wget下载),如:/usr/local/src
2:解压并迁移到我们以后都需要操作的mysql安装目录下:
tar  -xzvf   /usr/local/src/mysql-cluster-gpl-7.3.7-linux-glibc2.5-x86_64.tar.gz
mv  /usr/local/src/mysql-cluster-gpl-7.3.7-linux-glibc2.5-x86_64/*   /usr/local/mysql

3:新建mysql用户及用户组:
groupadd mysql
useradd -g mysql -s /usr/sbin/nologin mysql
chown -R mysql:mysql /usr/local/mysql

4:安装 My Cluster
cd /usr/local/mysql
./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

5:关闭防火墙(IPTABLES)与 selinux
chkconfig iptables off

vim /etc/selinux/config  #(改为SELINUX=disabled)保存退出

6:重启服务器
init 6


五、配置节点:
1 配置管理节点(10.10.10.41)
# 删除自带的 /etc/my.cnf  【切记:一定要删除掉! 因为ndb_mgmd启动的时候,也会加上/etc/my.cnf的配置内容,干扰我们,所以要删除它】
rm -rf /etc/my.cnf

# 新建配置文件存放目录
mkdir /usr/local/mysql/etc
chown mysql:mysql /usr/local/mysql/etc

# 创建配置文件 config.ini
vim /usr/local/mysql/etc/config.ini

# config.ini内容如下:
[ndb_mgmd default]
datadir = /usr/local/mysql/data
[ndbd default]
NoOfReplicas = 2
DataMemory = 80M
IndexMemory = 18M
datadir = /usr/local/mysql/data
[ndb_mgmd]
NodeId = 1
HostName = 10.10.10.41
[ndbd]
NodeId = 11  
HostName = 10.10.10.42
[ndbd]
NodeId = 12
HostName = 10.10.10.43
[mysqld]
NodeId = 81
HostName = 10.10.10.44
[mysqld] 
NodeId = 82
HostName = 10.10.10.45

2 配置数据节点(10.10.10.42、10.10.10.43)
# 修改配置文件
vim /etc/my.cnf

# my.cnf内容如下:
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
[mysql]
socket=/var/lib/mysql/mysql.sock

[mysqldump]
socket=/var/lib/mysql/mysql.sock

[mysqladmin]
socket=/var/lib/mysql/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

[mysqld]
ndbcluster
ndb-connectstring = 10.10.10.41
[mysql_cluster]
ndb-connectstring = 10.10.10.41

3 配置SQL节点(10.10.10.44、10.10.10.45)
# 拷贝文件
\cp -rf /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

# 修改配置文件
vim /etc/my.cnf

# my.cnf内容如下:
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
[mysql]
socket=/var/lib/mysql/mysql.sock
 
[mysqldump]
socket=/var/lib/mysql/mysql.sock
 
[mysqladmin]
socket=/var/lib/mysql/mysql.sock


# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

[mysqld]
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
ndbcluster
ndb-connectstring = 10.10.10.41
[mysql_cluster]
ndb-connectstring = 10.10.10.41


六、启动节点
启动需要按照如下顺序进行:
Management Node(管理节点) > Data Node(数据节点) > SQL Node(sql节点)
1 启动管理节点(10.10.10.41)
# --initial 用于首次加载、或者/usr/local/mysql/etc/config.ini文件有改变,其它时候不要加,除非是在备份、恢复或配置变化后重启时,其他时候不要加,不然数据就清空。。。
/usr/local/mysql/bin/ndb_mgmd  -f  /usr/local/mysql/etc/config.ini --initial

# 正常启动方式
/usr/local/mysql/bin/ndb_mgmd  -f  /usr/local/mysql/etc/config.ini

其他常用操作:
#查看ndb_mgmd是否启动
[root@localhost mysql]# ps -ef | grep ndb_mgmd
root      2948     1  1 23:47 ?        00:00:03 /usr/local/mysql/bin/ndb_mgmd -f /usr/local/mysql/etc/config.ini
root      2984  2073  0 23:52 pts/0    00:00:00 grep ndb_mgmd
[root@localhost mysql]#

说明一下:ndb_mgmd默认启动 1186 端口
[root@localhost mysql]# netstat -ntlp | grep ndb_mgmd
tcp        0      0 0.0.0.0:1186                0.0.0.0:*                   LISTEN      2948/ndb_mgmd   
[root@localhost mysql]#

#查看集群状态
[root@localhost etc]# /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=11   @10.10.10.42  (mysql-5.6.21 ndb-7.3.7, Nodegroup: 0, *)
id=12   @10.10.10.43  (mysql-5.6.21 ndb-7.3.7, Nodegroup: 0)

[ndb_mgmd(MGM)] 1 node(s)
id=1    @10.10.10.41  (mysql-5.6.21 ndb-7.3.7)

[mysqld(API)]   2 node(s)
id=81   @10.10.10.44  (mysql-5.6.21 ndb-7.3.7)
id=82   @10.10.10.45  (mysql-5.6.21 ndb-7.3.7)


2 启动数据节点(10.10.10.42、10.10.10.43)
# 只是在第一次启动或在备份/恢复或配置变化后重启ndbd时,才加–initial参数!
/usr/local/mysql/bin/ndbd --initial

# 正常启动方式
/usr/local/mysql/bin/ndbd

# 查看 ndbd 启动状态
[root@localhost ~]# ps -ef | grep ndbd
root      2373     1  0 18:11 ?        00:00:00 /usr/local/mysql/bin/ndbd
root      2377  1985  0 18:11 pts/0    00:00:00 grep ndbd

3 启动SQL节点(10.10.10.44、10.10.10.45)
# 启动 SQL 节点
service mysqld start

# 关闭 SQL 节点
service mysqld stop

# 重启 SQL 节点
service mysqld restart

# 检验mysql是否运行
service mysqld status

# 启动命令行窗口
/usr/local/mysql/bin/mysql -u root –p


留几个小坑给大家,譬如mysql的密码设置.譬如关闭集群.

程序猿行业技术生活交流群:181287753(指尖天下),欢迎大伙加入交流学习。

你可能感兴趣的:(mysql,集群,环境搭建,节点,数据库)