mysql ndb是什么_MySQL NDB Cluster介绍

最近翻译了好几篇关于NDB的文章,相信有很多人会有疑问,NDB Cluster究竟是个什么东西?它是一款新产品吗?它和InnoDB Cluster有什么不同?它是MySQL吗?它怎么使用?在这篇文章里,我将为大家介绍一下MySQL NDB Cluster是什么?它的架构和特征,以及它的适用场景。

MySQL NDB Cluster并不是一款新产品,它的最新版本8.0最近刚刚发布。追溯历史你会发现它最初的开发是由爱立信完成的,是的你没有看错,就是那个电信行业的爱立信,当初的名字叫做“Ericsson Network Database”。看到这里你大概会猜到这是一款什么样的产品了。它最初的目标对象是用来管理电信行业的数据,通过id进行关联的简单数据。最初的NDB是使用C++ API来访问数据的,MySQL将其收购以后,将其与SQL进行整合,现在的NDB既可以使用SQL,也可以C++ API 以及Java、memcached、Node.js等各种API进行访问。

MySQL NDB Cluster与MySQL Server(人们普遍认知的MySQL)是完全不同的产品,它使用非共享架构,通过多台服务器构建成集群,实现多点读写的关系型数据库。它具有在线维护功能,并且排除单一故障,具有非常高的可用性。此外,它的主要数据保存在内存中,可以高速处理大量的事务,是面向实时性应用程序的一款数据库产品。

MySQL NDB Cluster架构

MySQL NDB Cluster由三种节点构成,SQL节点、数据节点及管理节点。

4458e57d55a60e827265a3c52bf25d32.png

上图是由4个数据节点、2个SQL节点及2个管理节点组成的NDB集群

数据节点ndbmtd:负责管理数据、索引,控制事务处理。

SQL节点mysqld:应用程序和数据节点的SQL接口,用户认证,赋予权限等。

管理节点ndb_mgmd:启动停止集群、配置集群、备份,仲裁等。

数据节点:NDB Cluster的核心功能,用于保存数据、索引,控制事务。插入的数据按照主键的哈希值分散到不同的节点组里面保存(每个节点组保存部分数据),另外每个节点组内,数据会复制到不同的数据节点上以实现冗余。上图中节点组1保存了数据分片1和2两部分数据,节点组2里面保存了数据分片3和4两部分数据,每个节点组里面由2个数据节点构成,即使是每个节点组里面有一个节点发生故障,集群也能够持续运行。

SQL节点:相当于增加了NDB存储引擎的MySQL服务器,数据节点作为NDB存储引擎使用,如果使用其它的MySQL存储引擎,例如InnoDB,MyISAM等,数据将会保存在SQL节点上。应用程序通过SQL节点访问数据节点,使用方法与通常的MySQL一样,SQL节点会自动找到正确的数据节点将数据找回。

管理节点:管理节点用于配置集群和各个节点,各个节点需要连接管理节点,取得配置信息后加入集群。此外管理节点还充当仲裁者角色,以防止发生网络分区后出现脑裂现象。

NDB Cluster特征

高扩展性:NDB Cluster 可以在内部自动进行数据分片,随着数据节点的增加,可以做到非常高的读写扩展。

高可用性:最新版本高达99.9999%的高可用性,每年停机运维时间不超过1分钟。因为采用了非共享的架构,不会出现单一故障,发生故障时的故障转移时间非常短,并且各种维护工作可以在线进行,因此极大地提高系统可用性。

实时性:数据大部分情况下保存在内存中,可以快速执行事务,满足实时性高要求的应用需求。

异地容灾:可以利用NDB Cluster的复制功能,对NDB Cluster进行异地容灾,与MySQL的复制功能不同,NDB Cluster可以进行双向复制,并且能够对数据冲突进行校验。

SQL+NoSQL:数据节点上保存的数据除了可以通过SQL节点访问,还可以通过NoSQL访问。对比其它的KV型数据库,NDB Cluster具有如下优点:

支持ACID的完整事务。

数据具有持久性和冗余性。

自动故障转移。

在线备份。

低成本:由于NDB Cluster不使用共享存储,一般的服务器即可运行,因此可以为用户节省大量的硬件成本。

适用场景和案例

通过上面的介绍,您大致对NDB Cluster有了一些了解。基于它最初的基因,NDB Cluster广泛应用于电信行业,例如阿尔卡特朗讯,诺基亚,NEC等有大量的使用案例。在线游戏行业通过NDB进行会话管理,例如:Big Fish Games、Blizzard Entertainment、Zynga。此外,由于NDB具有非常高的可用性,美军航母的战机管控系统,PayPal的反欺诈系统均采用了NDB。NDB广泛适用于关键任务型系统。更多案例可以访问:https://www.mysql.com/why-mysql/case-studies/#en-5-28

以上是关于NDB的一个非常简明的介绍,今后计划写一下更详尽的内容。

感谢您关注MySQL!

欢迎关注公众号“MySQL解决方案工程师”

5e432b81d49ca6f0be95d2cb0e3d6888.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572534.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

orm和mysql_orm与mysql

一. orm执行原生sql语句在模型查询API不够用的情况下,我们还可以使用原始的SQL语句进行查询。Django 提供两种方法使用原始SQL进行查询:一种是使用raw()方法,进行原始SQL查询并返回模型实例;另一种是完全避开模型层,直…

课程作业2

作业二 题目 编写一个程序,要求根据给定的圆的半径求圆的面积,并将求得的结果打印出来。 要求: 输入输出采用cin和cout。 建立一个工程,将程序写成两个.cpp和一个.h的形式。 要求程序必须要对变量的定义和各个函数模块进行注释。 …

webform中提交按钮同时执行更新和插入操作_软件测试中的功能测试点(三)

26.输入法半角全角检查再输入信息中,输入一个或连串空格,查看系统如何处理,如对于要求输入符点型数据的项中,输入全角的小数点(“。”或“.”,如4.5);输入全角的空格等。 27.密码检查…

PAT甲题题解-1091. Acute Stroke (30)-BFS

题意:给定三维数组,0表示正常,1表示有肿瘤块,肿瘤块的区域>t才算是肿瘤,求所有肿瘤块的体积和 这道题一开始就想到了dfs或者bfs,但当时看数据量挺大的,以为会导致栈溢出,所以并没…

python如何获取请求的url_听说你在学习:如何通过代码请求URL地址

最近比较忙碌,都没有时间更新公众号文章,表示比较惭愧。最近翻看了一下自己的博客,发现这篇文章的内容还是挺实用,所以,想分享给大家,欢迎阅读。在后续,我会从一个范围的角度进行编写一系列文章…

在sql中将表建在别的构件中用什么语句_SQL实战

学习主题:SQL学习目标:1 掌握子查询1. 什么是子查询(1) 什么是子查询?答:当一个查询是另一个查询的条件时,称之为子查询。简而言之:嵌套查询(2) 子查询执行的顺序是什么?答:先进行内…

数据结构入门之链表(C语言实现)

这篇文章主要是根据《数据结构与算法分析--C语言描述》一书的链表章节内容所写,该书作者给出了链表ADT的一些方法,但是并没有给出所有方法的实现。在学习的过程中将练习的代码记录在文章中,并添加了一些在测试中需要的函数,因此可…

php 验证码需开启gd2

转载于:https://www.cnblogs.com/zhangj391/p/6794555.html

python中如何将字典直接变成二维数组_python基础知识(列表、字典、二维数组)...

记得改参数!!!(1)简述列表(list)结构的特点。List(列表)List的元素以线性方式存储,可以存放重复对象,List主要有以下两个实现类:ArrayList : 长度可变的数组,可以对元素进行随机的访问&#xff…

mysql动态代理_超全MyBatis动态代理详解(绝对干货)

前言假如有人问你这么几个问题,看能不能答上来Mybatis Mapper 接口没有实现类,怎么实现的动态代理JDK 动态代理为什么不能对类进行代理(充话费送的问题)抽象类可不可以进行 JDK 动态代理(附加问题)答不上来的铁汁,证明 Proxy、Mybatis 源码还…

python pygame鼠标点击_Python中pygame的mouse鼠标事件用法实例

本文实例讲述了Python中pygame的mouse鼠标事件用法。分享给大家供大家参考,具体如下:pygame.mouse提供了一些方法获取鼠标设备当前的状态pygame.mouse.get_pressed - get the state of the mouse buttons get the state of the mouse buttonspygame.mous…

java 建模_Java设计模式菜鸟系列(两)建模与观察者模式的实现

观察者(Observer)模式定义:在对象之间定义了一对多的依赖关系,这样一来。当一个对象改变状态时,依赖它的对象都会收到通知并自己主动跟新。Java已经提供了对观察者Observer模式的默认实现,Java对观察者模式的支持主要体如今Observ…

php多条件查询

需要查询的表格 代码&#xff1a; <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns"http://www.w3.org/1999/xhtml"> <head> <…

Airbert: In-domain Pretraining for Vision-and-Language Navigation

题目&#xff1a;Airbert&#xff1a;视觉和语言导航的域内预训练 摘要 为了解决VLN数据集稀缺的问题&#xff0c;本文创建了一个数据集BNB。我们首先从在线租赁市场的数十万个列表中收集图像标题 (IC) 对。接下来&#xff0c;我们使用 IC 对提出自动策略来生成数百万个 VLN …

实例讲解webpack的基本使用第二篇

这一篇来讲解一下如何设置webpack的配置文件webpack.config.js 我们新建一个webpack-demo的项目文件夹&#xff0c;然后安装webpack 执行如下命令 在项目文件夹下&#xff0c;建一个dist文件夹来放打包后的文件&#xff0c;以及一个src文件夹来放我们的代码文件 再建立一个inde…

java system.out.read_一个java文件操作小程序 system.out.in buffer read

按键 i buffer readabc123ET 0 97 代码停在此&#xff0c;等待输入 触发代码运行dET 0 …

java 当地时间_【JAVA】获取当地时间

Java代码 importjava.text.SimpleDateFormat;SimpleDateFormat formatter newSimpleDateFormat ("yyyy年MM月dd日 HH:mm:ss ");Date curDate newDate(System.currentTimeMillis());//获取当前时间String str formatter.format(curDate);impo…

java 优化线程_Java | 多线程调优(下):如何优化多线程上下文切换?

通过上一讲的讲解&#xff0c;相信你对上下文切换已经有了一定的了解了。如果是单个线程&#xff0c;在 CPU 调用之后&#xff0c;那么它基本上是不会被调度出去的。如果可运行的线程数远大于 CPU 数量&#xff0c;那么操作系统最终会将某个正在运行的线程调度出来&#xff0c;…

Go -- log4go日志

折腾&#xff1a; 【已解决】go语言中实现log信息同时输出到文件和控制台(命令行&#xff09; 期间&#xff0c;已经通过io的MultiWriter搞定了同时输出信息到文件和console&#xff0c;但是不支持level。 所以&#xff0c;再去试试这个log4go。 github.com/keepeye/log4go 【折…

Jmeter响应中中文乱码怎么解决?

在jmeter的bin目录下有一个jmeter.properties的文件&#xff0c;打开它&#xff0c;搜索sampleresult.default.encoding&#xff0c;把它的注释打开&#xff0c;也就是把最前面的#去掉&#xff0c;改成sampleresult.default.encodingUTF-8&#xff0c;保存&#xff0c;重新打开…