安装要求:
安装环境: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;

Centos6.5下安装Mysql集群的更多相关文章

  1. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  2. OpenStack对象存储――Swift

    Swift前身是RackspaceCloudFiles项目,随着Rackspace加入到OpenStack社区,于2010年7月贡献给OpenStack,作为该开源项目的一部分。Swift目前的最新版本是OpenStackEssex1.5.1。Swift特性在OpenStack官网中,列举了Swift的20多个特性,其中最引人关注的是以下几点。在OpenStack中还可以与镜像服务Glance结合,为其存储镜像文件。Auth认证服务目前已从Swift中剥离出来,使用OpenStack的认证服务Keysto

  3. 对象存储系统Swift技术详解:综述与概念

    通过阅读Swift的技术文档,我们可以理解其中的设计的原理和实现的方法。本人于9月底开始接触swift,刚开始看文档的时候一知半解,有幸阅读了zzcase等人的博客,才得以入门。随着对swift设计原理的理解和源码的深入,文档经过数次反复的修改,希望对各位学习swift的童鞋有所帮助,水平有限,若各位发现有错误之处,恳请指出。

  4. 《转》OpenStack对象存储——Swift

    Swift前身是RackspaceCloudFiles项目,随着Rackspace加入到OpenStack社区,于2010年7月贡献给OpenStack,作为该开源项目的一部分。Swift目前的最新版本是OpenStackEssex1.5.1。Swift特性在OpenStack官网中,列举了Swift的20多个特性,其中最引人关注的是以下几点。在OpenStack中还可以与镜像服务Glance结合,为其存储镜像文件。Auth认证服务目前已从Swift中剥离出来,使用OpenStack的认证服务Keysto

  5. openstack学习笔记七 swift安装

    指定映射位置创建ring文件启动服务代维服务proxyserver

  6. openstack安装liberty--安装对象存储服务swift

    通常使用CACHE技術提高性能Accountservers賬戶服務,管理對象存儲中的賬戶定義。Containerservers容器服務,在對象存儲中管理容器或文件夾映……Objectservers對象服務,在存儲節點管理實際的對象,比如文件。Wsgimiddleware處理認證,通常使用OPENSTACKIdentityswiftclient為用戶提供命令行接口使用RESTAPIswift-init初始化和構建RING文件腳本swift-recon一個命令行工具,用於檢索群集的各種度量和測試信息。

  7. 在Android上同步SQL数据库与REST远程服务器的最佳实践

    编辑:例如,采用方法2,重写的ContentProvider#bulkInsert使用数据库事务可以大大加快批量插入操作:见thisquestion.解决方法最佳选择需要适当的API实现–何时应存储一些db_version.并且在更新服务器期间响应数据和操作类型–添加,更新,删除.

  8. 可以从Android SQLiteConstraintException获取特定的错误详细信息?

    我对某些数据收到以下错误,概念很清楚:但是,这并没有帮助我找到哪个特定记录具有无效的FK.而不是颠覆我的代码并尝试用新事务隔离每个插入,是否有任何方法可以打开(或提取)日志记录,使用有用的详细信息,例如有问题的表,甚至导致问题的FK值?

  9. android – 没有SQL的ContentProvider

    我有两个数据需要从外部应用程序访问并存储.根据文档,ContentProviders是唯一可能的方式,但它也提到了外部存储.ContentProviders实现类似数据库的“接口”,对于两个数据,使用数据库是非常不必要的.我宁愿将它们保存到文件中,但是通过实现抽象方法使用ContentProvider是有问题的,因为这些方法被构造为数据库查询.我知道没有任何指定ContentProviders必须使用下面的数据库来存储数据,但有没有其他方法来存储必须共享到文件系统的最小数据量?

  10. Android SQL:检查数据库中的记录是否存在

    我正在尝试根据特定的ID查询我的数据库.如果这是第一次运行活动,则表将与id列一起存在,但不会有具有特定ID的记录.如何检查特定记录是否存在,如果不存在,请添加它?关于检查特定列是否存在,我发现了很多内容,但没有关于检查特定记录是否存在的信息.到目前为止,我已经尝试获取id列索引并检查它是否返回-1,但实际上由于某种原因返回1.我可以在if语句中使用什么来验证是否尚未创建id列?

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部