搭建mysql cluster
虚拟机搭建Mysql Cluster
参考文档:http://www.cnblogs.com/jackluo/archive/2013/01/19/2868152.html
http://www.cnblogs.com/StanBlogs/archive/2011/06/14/2080986.html
需要三台服务器。一个管理节点服务器。另外两个均充当数据节点和sql节点。
这里选用ubuntu64位操作系统。mysql cluster 对应也必须是64位的。去官方站点下载mysql-cluster-gpl-7.4.4-linux-glibc2.5-x86_64。
(注:当在虚拟机操作时,vmware下,可以只先操作一个sql节点,然后虚拟机有克隆功能,直接整一份,这样另一个sql节点就基本搞定了,只需要更改下ip即可。在虚拟机实验下,最好整快照或克隆。
我这里,管理节点ip是192.168.1.232
另两个机器,既充当数据节点也是sql节点。ip是192.168.1.210 ; 192.168.1.219
)
安装ubuntu操作系统后,更改ip,dns配置。
切换用户 sudo passwd root,然后创建个root用户密码。
su root后,输入root密码。
以下操作利用root用户进行。
对每个机器的ip配置:
vim /etc/network/interfaces
改内容如下:
auto eth0
iface eth0 inet static #这里没用dhcp动态,取静态ip
address 192.168.1.219 #ip地址
gateway 192.168.1.1 #网关地址
netmask 255.255.255.0 #子网掩码
dns-nameservers 192.168.1.1 #dns解析
重启网络设置:
sudo /etc/init.d/networking restart
一. 对数据节点和sql节点的操作
1. 创建组,用户
groupadd mysql
useradd -g mysql mysql
2. 下载mysql cluster64。传这个文件到某个目录下。这里直接上传到/usr/local(如果利用文件上传服务器,则需要赋给权限如chmod 766 /usr/local)
解压: tar -xvf mysql.tar.gz
改名: mv mysql-cluster-gpl-7.4.4-linux-glibc2.5-x86_64 mysql
3. 修改mysql目录权限
cd mysql
chown -R root .
chown -R mysql data
chgrp -R mysql .
4. 安装mysql初始库
在mysql目录下:
scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql
5. 把mysql设置为开机自启
可以把mysql服务开机自启。不整也行。
6.这里设置mysql配置文件,这里缺省了mysql配置的性能方面参数。
vim /etc/my.cnf
[client]
socket=/usr/local/mysql/sock/mysql.sock
[mysqld]
ndbcluster
datadir=/usr/local/mysql/data
socket=/usr/local/mysql/sock/mysql.sock
ndb-connectstring=192.168.1.232 #这个是管理节点的ip
old_passwords=1
default-storage-engine=ndbcluster #可以省略建表的引擎语句(只有引擎是ndb的才可以起到集群的作用)
[mysql_cluster]
ndb-connectstring=192.168.1.232 #这里配置的是管理节点服务器地址
7. 此时不必启动mysql服务。
以上的操作,需要在多台数据节点和sql节点机器上进行(要是虚拟机,就克隆就好了,然后改下ip)。
二. 对管理节点的操作
管理节点不需要安装mysql服务。只需要mysql-cluster解压后的两个文件,分别是
sql节点服务器上:/usr/local/mysql/bin/ndb_mgmd 和 /usr/local/mysql/bin/ndb_mgm
ndb_mgmd 是管理节点的服务
ndb_mgm 是管理节点的客户端查看用
1. 把sql节点上的这两个文件拷贝到管理节点的/usr/local/bin目录下。(我使用filezilla传过去的)
2. 在管理节点上,确保这两个文件可执行。
cd /usr/local/bin
chmod +x ndb_mgm*
3. 在/usr/local下创建mysql文件夹,确保数据节点打开服务时,可以生成log文件
mkdir /usr/local/mysql
4. 创建一个管理节点的配置文件
mkdir /var/lib/mysql-cluster
cd /var/lib/mysql-cluster
vim config.ini
[NDBD DEFAULT]
NoOfReplicas=2
MaxNoOfTables = 1024 #所有ndbcluster引擎的表数量最大数
MaxNoOfAttributes = 7000 #所有ndbcluster引擎的表的所有字段数量最大数
MaxNoOfOrderedIndexes = 10000
[TCP DEFAULT]
portnumber=22202
[NDB_MGMD]
hostname=192.168.1.232 #管理节点
datadir=/var/lib/mysql-cluster/
[NDBD]
hostname=192.168.1.210 #数据节点
datadir=/usr/local/mysql/data/
[NDBD]
hostname=192.168.1.219 #数据节点
datadir=/usr/local/mysql/data/
[MYSQLD]
# 这里配置sql节点,最好留空。
[MYSQLD]
三、启动mysql cluster
注意启动顺序:首先是管理节点,然后是数据节点,最后是SQL节点,这里数据节点和sql节点是同一个机器。
1. ndb_mgmd -f /var/lib/mysql-cluster/config.ini --initial
第一次启动时,再加--initial参数,或者在更改config.ini节点时加
(启动时可能会报个WARNING,如WARNING -- at line 7: [TCP] portnumber is deprecated,这个不用管就是端口号不建议使用了,warning的级别不如error。可以正常工作的。)
此时使用ndb_mgm来监听客户端
2. 数据节点
/usr/local/mysql/bin/ndbd
首次启动,则需要添加--initial参数,以便进行NDB节点的初始化工作。在以后的启动过程中,则是不能添加该参数的,否则ndbd程序会清除在之前建立的所有用于恢复的数据文件和日志文件。(如果报错:日志文件不能生成,则手动创建这个目录)
此时,在管理节点上,ndb_mgm,使用show命令时,可以看到数据节点连接上了(多台数据节点都需要这样操作)
3. sql节点
/usr/local/mysql/bin/mysqld_safe --user=mysql &
如果报错说某套接字连不上mysql,那么尝试下再次创建系统数据库,方法如下:
在mysql目录下
scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql
再次启动
/usr/local/mysql/bin/mysqld_safe --user=mysql &
查看管理节点。此时sql节点也应该连接上了。
四、测试
1、常规测试:
在一个节点比如A节点,上面:
为了让表在cluster中正常复制,创建一个表必须使用ndbcluster引擎(engine=ndb Or engine=ndbcluster)方法如下:
mysql>use test
mysql>create table teacher(t_id int) engine=ndb;(这里引擎须要是ndb,而不是innodb或其他)
如果是一个已经存在的表,用alter table修改表的引擎。
mysql>alter table teacher engine=ndb;
插入一条数据:
mysql>insert into teacher values(133);
然后在B节点上查看:
mysql>select * from teacher;
A、B两个节点数据保持一致,那就测试成功了哈哈,遇到什么问题网上查一下资料什么的!
模拟NDB节点Crash:
这个测试,基本参照文档:
http://www.cnblogs.com/StanBlogs/archive/2011/06/14/2080986.html
=================================================================================
备注给需要的童鞋:
1 查看某机器下,该系统支持的存储引擎
show engines;
2 查看表使用的存储引擎
show table status from db_name where name='table_name';
3. 更改表引擎
alter table student engine=ndb;
=================================================================================
如果你想连接你的mysql的时候发生这个错误:
ERROR 1130: Host '192.168.1.3' is not allowed to connect to this MySQL server
解决方法:
1. 授权法。
如果你想允许用户myuser从ip为192.168.1.3的主机连接到mysql服务器,并使用mypassword作为密码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.3' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;
=================================================================================
当需要关闭数据节点或sql节点下的某服务,如关闭ndbd服务或mysql服务
可以这样
ps aux | grep mysql
ps aux | grep ndbd
然后找到进程号,
利用 kill -9 pid(进程号)
搭建mysql cluster的更多相关文章
- Windows系统搭建Mysql Cluster集群
简单介绍一下MySQL集群涉及的三种节点: 管理节点(也可以称管理服务器)是整个集群环境的核心,类似于集群中起调度作用的枢纽,由它来负责管理其它节点(数据节点和SQL节点)的开启.关闭或重启某 ...
- MySQL集群---②Windows平台搭建MySQL CLUSTER集群
原文:http://blog.csdn.net/mazhaojuan/article/details/42211857 本文将通过两台电脑来简单介绍一下Windows平台如何搭建MySQL集群. My ...
- MySQL Cluster搭建与测试
MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和Oracle Real Cluster Ap ...
- MySQL Cluster 集群
本文转载 http://www.cnblogs.com/gomysql/p/3664783.html MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅 ...
- 第 16 章 MySQL Cluster
前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和 Oracle Real Cl ...
- MySql(十六):MySql架构设计——MySQL Cluster
前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和 Oracle Real Cl ...
- MySQL性能调优与架构设计——第 16 章 MySQL Cluster
第 16 章 MySQL Cluster 前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等 ...
- 超详细,多图文使用galera cluster搭建mysql集群并介绍wsrep相关参数
超详细,多图文使用galera cluster搭建mysql集群并介绍wsrep相关参数 介绍galera cluster原理的文章已经有一大堆了,百度几篇看一看就能有相关了解,这里就不赘述了.本文主 ...
- centos7 mysql cluster集群搭建基于docker
1.准备 mn:集群管理服务器用于管理集群的其他节点.我们可以从管理节点创建和配置集群上的新节点.重新启动.删除或备份节点. db2/db3:这是节点间同步和数据复制的过程发生的层. db4/db5: ...
随机推荐
- Ps—导出:sql作业配合ps导出csv文件
$dateText=Get-Date #获取当前日期时间 $dateText = $dateText.ToShortDateString() #转为短日期格式(去掉时间部分) $checkDate=( ...
- JavaScript数组学习总结
数组 数组 1.数组:数组是一组数据(数据类型不限,任意)的有序集合===>我们写代码,一般一个数组只放一种数据类型的数据 2.我们写代码,一般一个数组只放一种类型的数据 3.注意: 大多数 ...
- 微信小程序转发功能
微信小程序转发涉及以下4个方法: 1.Page.onShareAppMessage({}) 设置右上角“转发”配置,及转发后回调函数返回 shareTicket 票据 2.wx.showSahreMe ...
- 【转】巧用DOS tree命令+批处理 实现 指定文件 批量复制!
转自:http://www.cnblogs.com/looky/archive/2010/01/24/1655292.html 今天一朋友叫我帮忙解决指定文件批量复制的问题,于是找了一大堆批处理命令, ...
- loadrunner 脚本优化-关联函数web_reg_save_param()函数详解
脚本优化-关联函数web_reg_save_param()函数详解 by:授客 QQ:1033553122 Insert->New Step,打开Add Step对话框 选择函数web_re ...
- 表单元素的required,autocomplete,list用法
required: 当在一个表单元素如:input中加上required属性时,点击提交表单按钮,针对input会弹出一个默认的警告信息,如下图: 代码如下: <form id="my ...
- maven五:查找jar包坐标,选择jar包版本
查找jar包坐标 以spring core的jar包为例,访问http://www.mvnrepository.com/ 在最上方中间,输入spring core,点击Search. 搜索结果第 ...
- php处理手机号中间的四位为星号****
在显示用户列表的场景中,一般用到手机号的显示时都需要对手机号进行处理,一般是把中间的四位换成星号****,我本人用php处理的思路是进行替换,用****替换手机号的中间四位 代码如下: $all_lo ...
- 系统运维|IIS的日志设置
摘要: 1.服务器告警,磁盘资源不足 2.检查发现是IIS日志没有清理并且设置有误.在E盘占用了200G的空间 3.原则上IIS日志不能放在C盘,避免C盘写满了导致操作系统异常 4.附上IIS日志按天 ...
- row_number() over() 一句话概括,以及max()函数的一种查询分组中最大值的用法
row_number() over(partition by col1 order by col2) 根据COL1分组可能会有多个组,每组组内根据COL2进行排序.每组内都有自动生成的序号,从1开始, ...