SQL节点: 给上层应用层提供sql访问。

管理节点(MGM):  管理整个集群。 启动,关闭集群。 通过ndb_mgmd命令启动集群

存储/数据节点: 保存cluster中的数据。  数据节点,可以提供副本。实现数据冗余。

NDB引擎:是一种 “内存中”的存储引擎 , 它具有可用性高和数据一致性好的特点。

缺陷

  • 基于内存,数据库的规模受集群总内存的大小限制
  • 基于内存,断电后数据可能会有数据丢失,这点还需要通过测试验证。
  • 多个节点通过网络实现通讯和数据同步、查询等操作,因此整体性受网络速度影响,因此速度也比较慢

2.2 优点

  • 多个节点之间可以分布在不同的地理位置,因此也是一个实现分布式数据库的方案。
  • 扩展性很好,增加节点即可实现数据库集群的扩展。
  • 冗余性很好,多个节点上都有完整的数据库数据,因此任何一个节点宕机都不会造成服务中断。

Mysql cluster的下载地址:http://dev.mysql.com/downloads/cluster/

在我们做的实验中mysql cluster集群各机器角色如下分配:

mysql管理结点:xuegod63.cn   IP:192.168.31.130

mysql 数据结点:xuegod63.cn   IP:192.168.31.130

mysql 数据结点:xuegod64.cn   IP:192.168.31.131

msyql SQL结点:xuegod63.cn   IP:192.168.31.130

msyql SQL结点:xuegod64.cn   IP:192.168.31.131

将MySQL-Cluster-gpl-7.3.7-1.el6.x86_64.rpm-bundle.tar上传到130,131主机

实战:MySQL集群搭建

1.mysql旧版本清除

yum -y remove mysql

rpm -qa | grep mysql*

对于找到的2个剩余mysql包,请按照如下的命令格式予以删除:

rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64

2.mysql cluster版本安装准备

[root@ygy130 ~]# tar -xvf MySQL-Cluster-gpl-7.3.7-1.el6.x86_64.rpm-bundle.tar

[root@yu131 yy]# tar -xvf MySQL-Cluster-gpl-7.3.7-1.el6.x86_64.rpm-bundle.tar

3.创建文件夹

(分如下3个类来创建对应的文件夹)

数据结点存放数据,: [root@ygy130 ~]# mkdir /var/lib/mysql

管理节点: [root@ygy130 ~]# mkdir /var/lib/mysql-cluster     SQL节点:可不用  文件夹授权

进程DIR:     [root@ygy130 ~]# mkdir /var/run/mysqld

[root@yu131 yy]# mkdir /var/run/mysqld

4.安装mysql集群软件包

[root@ygy130 ~]# rpm -ivh MySQL-Cluster-server-gpl-7.3.7-1.el6.x86_64.rpm

[root@ygy130 ~]# rpm -ivh MySQL-Cluster-client-gpl-7.3.7-1.el6.x86_64.rpm

[root@yu131 yy]# rpm -ivh MySQL-Cluster-server-gpl-7.3.7-1.el6.x86_64.rpm

[root@yu131 yy]# rpm -ivh MySQL-Cluster-client-gpl-7.3.7-1.el6.x86_64.rpm

注意:当安装完毕MySQL-Cluster-server-gpl包后,将出现如下提示信息,提醒我们整个cluster安装后的初次超级账户密码存在/root/.mysql_secret这个文件当中。

5.赋权限

[root@ygy130 ~]# chown mysql:mysql -R /var/lib/mysql

[root@ygy130 ~]#  chown mysql:mysql -R /var/lib/mysql-cluster/

[root@ygy130 ~]# chown mysql:mysql -R  /usr/mysql-cluster/

[root@ygy130 ~]#  chown mysql:mysql -R /var/run/mysqld/

[root@ygy130 ~]# chown mysql:mysql -R /usr/mysql-cluster/

[root@yu131 yy]# chown mysql:mysql -R /var/run/mysqld

 搭建mysql集群

[root@ygy130 ~]# vim /var/lib/mysql-cluster/config.ini

[ndbd default]
NoOfReplicas=2    #数据写入数量。2表示两份
DataMemory=200M
IndexMemory=100M  #索引给100M

[ndb_mgmd]
id=1
datadir=/var/lib/mysql-cluster   # 管理结点的日志

HostName=192.168.31.130    #管理结点的IP地址。本机IP
###### data node options:
[ndbd]
HostName=192.168.31.130
DataDir=/var/lib/mysql          #mysql数据存储路径

id=2
[ndbd]
HostName=192.168.31.131  
DataDir=/var/lib/mysql 
id=3
# SQL node options: #关于SQL结点
[mysqld]
HostName=192.168.31.130
id=4
[mysqld]
HostName=192.168.31.131
id=5

~
数据节点+SQL节点配置文档 + 主从同步

[root@ygy130 ~]# vim /etc/my.cnf

[mysqld]
datadir=/var/lib/mysql              #mysql数据存储路径  数据节点(配置要加)

ndbcluster                #启动ndb引擎

ndb-connectstring=192.168.31.130    # 管理节点IP地址

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
[mysql_cluster]
ndb-connectstring=192.168.31.130       #管理节点IP地址
[mysqld]
log-bin=mysql-bin-master         #配置主从同步
server-id = 10

[root@yu131 yy]# vim /etc/my.cnf

[mysqld]
datadir=/var/lib/mysql
ndbcluster
ndb-connectstring=192.168.31.130
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
[mysql_cluster]
ndb-connectstring=192.168.31.130
[mysqld]
log-bin=mysql-bin-slave
server-id = 11
~

MySQL Cluster启动

[root@ygy130 ~]# ndb_mgmd -f /var/lib/mysql-cluster/config.ini

[root@ygy130 ~]# ndbd --initial              第一次启动加--initial

[root@yu131 yy]# ndbd --initial

启动SQL结点服务

[root@yu131 yy]# mysqld_safe --defaults-file=/etc/my.cnf  &

[root@ygy130 ~]# mysqld_safe --defaults-file=/etc/my.cnf  &

设置密码及相关mysql设置

[root@ygy130 ~]# cat /home/yy/.mysql_secret

[root@ygy130 ~]# mysql_secure_installation

[root@yu131 yy]# cat  /root/.mysql_secret

[root@yu131 yy]# mysql_secure_installation

查看mysql 集群状态:

[root@ygy130 ~]# ndb_mgm

130

mysql> grant replication slave on *.* to slave@192.168.31.131 identified by "123456";

mysql> flush privileges;

131

mysql>change master to master_host='192.168.31.130',master_user='slave',master_password='123456';

mysql> start slave;

mysql> show slave status\G  查看状态

130

mysql> create database yy;

mysql> use yy

mysql> create table tt(id int);

mysql> insert into tt values(11);

131

mysql> use yy

mysql> select * from tt;

关闭服务

[root@ygy130 ~]#  ndb_mgm

-- NDB Cluster -- Management Client --

ndb_mgm> shutdown

ndb_mgm> exit

[root@ygy130 ~]# ps -axu | grep  ndbd           #查看不到,说明数据节点已经被关

[root@ygy130 ~]# kill -9 pid号

[root@yu131 yy]# ps -axu | grep  ndbd           #查看不到,说明数据节点已经被关

[root@yu131 yy]# kill -9 pid号

启动服务

[root@ygy130 ~]# ndb_mgmd -f /var/lib/mysql-cluster/config.ini

[root@ygy130 ~]# ndbd

[root@yu131 yy]#  ndbd

[root@yu131 yy]# mysqld_safe --defaults-file=/etc/my.cnf  &

[root@ygy130 ~]# mysqld_safe --defaults-file=/etc/my.cnf  &

备注:集群做了数据库的同步,没有做数据库表的同步,具体还是没有理解这样做的意义,如果集群不能主从同步,那么之前画的那个图就不准确。

  因此这里自定义加的数据库表的同步:采用主从同步的方式。

  后期做成M-s s-M,这样无论修改哪一边的数据,都能同步了。

mysql 集群+主从同步的更多相关文章

  1. mysql 集群 数据同步

    mysql集群配置在网站负载均衡中是必不可少的: 首先说下我个人准备的负载均衡方式: 1.通过nginx方向代理来将服务器压力分散到各个服务器上: 2.每个服务器中代码逻辑一样: 3.通过使用redi ...

  2. 高可用性、负载均衡的mysql集群解决方案

    高可用性.负载均衡的mysql集群解决方案 一.mysql的市场占有率 二.mysql为什么受到如此的欢迎 三.mysql数据库系统的优缺点 四.网络服务器的需求 五.什么是mysql的集群 六.什么 ...

  3. MySql集群FAQ----mysql主从配置与集群区别、集群中需要多少台计算机呢?为什么? 等

    抽取一部分显示在这里,如下, What's the difference in using Clustervs using replication? 在复制系统中,一个MySQL主服务器会更新一个或多 ...

  4. 浅谈mysql集群

    一.什么是MySQL集群 MySQL集群是一个无共享的(shared-nothing).分布式节点架构的存储方案,其目的是提供容错性和高性能. 数据更新使用读已提交隔离级别(read-committe ...

  5. MySQL集群(二)之主主复制

    前面介绍了主从复制,这一篇我将介绍的是主主复制,其实听名字就可以知道,主主复制其实就是两台服务器互为主节点与从节点.接下来我将详细的给大家介绍,怎么去配置主主复制! 一.主从复制中的问题 1.1.从节 ...

  6. MySQL集群PXC的搭建

    MySQL集群PXC的搭建 最近公司某客户要求我们的数据库搭建PXC集群以保证他们的系统高性能和搞稳定性 以后花费了一些时间去搭建和测试,也踩过一些坑,准备分享出来 系统:centos6.6PXC:5 ...

  7. 集群技术(三)MySQL集群深度解析

    什么是MySQL集群 MySQL集群是一个无共享的(shared-nothing).分布式节点架构的存储方案,其目的是提供容错性和高性能. 数据更新使用读已提交隔离级别(read-committedi ...

  8. MySQL集群架构:MHA+MySQL-PROXY+LVS实现MySQL集群架构高可用/高性能-技术流ken

    MHA简介 MHA可以自动化实现主服务器故障转移,这样就可以快速将从服务器晋级为主服务器(通常在10-30s),而不影响复制的一致性,不需要花钱买更多的新服务器,不会有性能损耗,容易安装,不必更改现有 ...

  9. 关于MySQL集群的一些看法

    作者:Gary Chen链接:https://zhuanlan.zhihu.com/p/20204156来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 市面上的招聘往往 ...

随机推荐

  1. How to Fix GNOME License Not Accepted Issue on CentOS 7

    This post assume that you have just finished the Gnome GUI installation on CentOS 7 by using “yum gr ...

  2. Python学习笔记(五)——list和tuple

    一.list 1.定义: list是一种有序的集合,可以随时添加和删除其中的元素 2.声明方法: subjects=['Math','English', 'Chinese'] 3.一些api (1)获 ...

  3. salesforce 零基础学习(四十二)简单文件上传下载

    项目中,常常需要用到文件的上传和下载,上传和下载功能实际上是对Document对象进行insert和查询操作.本篇演示简单的文件上传和下载,理论上文件上传后应该将ID作为操作表的字段存储,这里只演示文 ...

  4. 409. Longest Palindrome

    Given a string which consists of lowercase or uppercase letters, find the length of the longest pali ...

  5. 【maven 报错】maven项目执行maven install时报错Error assembling WAR: webxml attribute is required (or pre-existing WEB-INF/web.xml if executing in update mode)

    在使用maven新建的web项目中,执行 执行如上的这两个操作,报错: [ERROR] Failed to execute goal org.apache.maven.plugins:maven-co ...

  6. C#实现监控网络流量

    本文转载自:http://blog.csdn.net/zhanjianshinian/article/details/8177851 public partial class NetJiankongF ...

  7. Codeforces Round #217 (Div. 2) c题

    C. Mittens time limit per test 1 second memory limit per test 256 megabytes input standard input out ...

  8. JAVA 修改 JSESSIONID

    @Action("sidTest") public void sidTest() { HttpSession session = request.getSession(); Str ...

  9. DotNetNuke-DNN Module模块引用自定义CSS或者JS文件

    当新增一个module时,有时会引用自定义的或者第三方CSS.JS文件. 1.添加自定义的CSS时,可以直接在module的根目录下添加module.css,然后框架会自动加载此CSS: 2.这个比较 ...

  10. 过滤器Filter(17/4/8)

    1:是JavaWeb三大组件之一: Servlet.Lisener(2个感知监听器不需要配置).Filter 2:过滤器 它会在一组资源(jsp.servlet.css.html等等)的前面执行! 它 ...