iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >NoSQL比较火的三个数据库Memcached、Redis、MongoDB
  • 359
分享到

NoSQL比较火的三个数据库Memcached、Redis、MongoDB

NoSQL比较火的三个数据库MemcachedRedisMongoDB 2019-11-09 11:11:59 359人浏览 绘本
摘要

NoSQL,泛指非关系型的数据库。随着互联网不断的发展,传统的关系数据库在应付新互联网模式的网站,特别是超大规模和高并发的SNS类型的纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了

NoSQL比较火的三个数据库Memcached、Redis、MongoDB

NoSQL,泛指非关系型的数据库。随着互联网不断的发展,传统的关系数据库在应付新互联网模式的网站,特别是超大规模和高并发的SNS类型的纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。Nosql数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题。而今天主要讲用得比较多的三个NoSQL:Memcached、RedismongoDB

Memcached

优点

Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key、value的字节大小以及服务器硬件性能,日常环境中QPS高峰大约在4-6w左右)。适用于最大程度扛量。

支持直接配置为session handle。

缺点

只支持简单的key/value数据结构,不像Redis可以支持丰富的数据类型。

无法进行持久化,数据不能备份,只能用于缓存使用,且重启后数据全部丢失。

无法进行数据同步,不能将MC中的数据迁移到其他MC实例中。

Memcached内存分配采用Slab Allocation机制管理内存,value大小分布差异较大时会造成内存利用率降低,并引发低利用率时依然出现踢出等问题。需要用户注重value设计。

Redis

优点

支持多种数据结构,如 string(字符串)、 list(双向链表)、dict(hash表)、set(集合)、zset(排序set)、hyperloglog(基数估算)。

支持持久化操作,可以进行aof及rdb数据持久化到磁盘,从而进行数据备份或数据恢复等操作,较好的防止数据丢失的手段。

支持通过Replication进行数据复制,通过master-slave机制,可以实时进行数据的同步复制,支持多级复制和增量复制,master-slave机制是Redis进行HA的重要手段。

线程请求,所有命令串行执行,并发情况下不需要考虑数据一致性问题。

支持pub/sub消息订阅机制,可以用来进行消息订阅与通知。

支持简单的事务需求,但业界使用场景很少,并不成熟。

缺点

Redis只能使用单线程,性能受限于CPU性能,故单实例CPU最高才可能达到5-6wQPS每秒(取决于数据结构,数据大小以及服务器硬件性能,日常环境中QPS高峰大约在1-2w左右)。

支持简单的事务需求,但业界使用场景很少,并不成熟,既是优点也是缺点。

Redis在string类型上会消耗较多内存,可以使用dict(hash表)压缩存储以降低内存耗用。

MonGoDB

优点

更高的写负载,MongoDB拥有更高的插入速度。

处理很大的规模的单表,当数据表太大的时候可以很容易的分割表。

高可用性,设置M-S不仅方便而且很快,MongoDB还可以快速、安全自动化的实现节点(数据中心)故障转移。

快速的查询,MongoDB支持二维空间索引,比如管道,因此可以快速及精确的从指定位置获取数据。MongoDB在启动后会将数据库中的数据以文件映射的方式加载到内存中。如果内存资源相当丰富的话,这将极大地提高数据库的查询速度。

非结构化数据的爆发增长,增加列在有些情况下可能定整个数据库,或者增加负载从而导致性能下降,由于MongoDB的弱数据结构模式,添加1个新字段不会对旧表格有任何影响,整个过程会非常快速。

缺点

不支持事务。

MongoDB占用空间过大 。

MongoDB没有成熟的维护工具

Memcached、Redis、MongoDB的区别

性能

三者的性能都比较高,总的来讲:Memcached和Redis差不多,要高于MongoDB。

便利性

Memcached数据结构单一。

Redis丰富一些,数据操作方面,Redis更好一些,较少的网络IO次数。

MongoDB支持丰富的数据表达,索引,最类似关系型数据库,支持的查询语言非常丰富。

存储空间

Memcached可以修改最大可用内存,采用LRU算法

Redis在2.0版本后增加了自己的VM特性,突破物理内存的限制;可以对key value设置过期时间(类似memcached)。

MongoDB适合大数据量的存储,依赖操作系统VM做内存管理,吃内存也比较厉害,服务不要和别的服务在一起。

可用性

Memcached本身没有数据冗余机制,也没必要;对于故障预防,采用依赖成熟的hash或者环状的算法,解决单点故障引起的抖动问题。

Redis,依赖客户端来实现分布式读写;主从复制时,每次从节点重新连接主节点都要依赖整个快照,无增量复制,因性能和效率问题,所以单点问题比较复杂;不支持自动sharding,需要依赖程序设定一致hash 机制。一种替代方案是,不用redis本身的复制机制,采用自己做主动复制(多份存储),或者改成增量复制的方式(需要自己实现),一致性问题和性能的权衡。

MongoDB支持master-slave,replicaset(内部采用paxos选举算法,自动故障恢复),auto sharding机制,对客户端屏蔽了故障转移和切分机制。

可靠性

Memcached不支持,通常用在做缓存,提升性能。

Redis支持(快照、AOF):依赖快照进行持久化,aof增强了可靠性的同时,对性能有所影响。

MongoDB从1.8版本开始采用binlog方式支持持久化的可靠性。

一致性

Memcached在并发场景下,用cas保证一致性。

Redis事务支持比较弱,只能保证事务中的每个操作连续执行。

MongoDB不支持事务。

数据分析

MongoDB内置了数据分析的功能(mapReduce),其他两者不支持。

应用场景

Memcached:用于在动态系统中减少数据库负载,提升性能;做缓存,提高性能(适合读多写少,对于数据量比较大,可以采用sharding)。

Redis:数据量较小的高性能操作和运算上。

MongoDB:主要解决海量数据的访问效率问题。

总结分析

若是简单的存取key-value(主要是读)这样的数据用Memcached好一些。若是要支持数据持久化,量也不大,操作很频繁,多数据类型(如集合、散列之类的),用列表类型做队列之类的高级应用,就用Redis,但如果是数据量比较大时就采用MongoDB。

Memcached的很多客户端更加成熟稳定,Redis协议比Memcached复杂。Redis不可能比Memcached快?但是测试结果基本是Redis占绝对优势。

云数据库Memcached版实例中的数据是存储在内存中的,当出现宕机、机房断电等意外,或是云数据库Memcached版实例在正常升级维护时,内存中的数据均会丢失。因此,云数据库Memcached版不能作为持久化的数据存储服务使用。Redis的数据都存放在内存中,如果没有配置持久化,Redis重启后数据就全丢失了,于是需要开启Redis的持久化功能,将数据保存到磁盘上,当Redis重启后,可以从磁盘中恢复数据,实现持久化。

对于Redis和MongoDB来说,大家一般称之为Redis缓存、MongoDB数据库。Redis主要把数据存储在内存中,其“缓存”的性质远大于其“数据存储“的性质,其中数据的增删改查也只是像变量操作一样简单;MongoDB却是一个“存储数据”的系统,增删改查可以添加很多条件,就像SQL数据库一样灵活。

MongoDB和Redis都是NoSQL,采用结构型数据存储。二者在使用场景中,存在一定的区别,这也主要由于二者在内存映射的处理过程,持久化的处理方法不同。MongoDB建议集群部署,更多的考虑到集群方案,Redis更偏重于进程顺序写入,虽然支持集群,也仅限于主-从模式

推荐:妆组词

您可能感兴趣的文档:

--结束END--

本文标题: NoSQL比较火的三个数据库Memcached、Redis、MongoDB

本文链接: https://www.lsjlt.com/news/5578.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • NoSQL的三个数据库Memcached和Redis以及MongoDB对比是怎样的
    这期内容当中小编将会给大家带来有关NoSQL的三个数据库Memcached和Redis以及MongoDB对比是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章...
    99+
    2024-04-02
  • PHP与NoSQL数据库的对比
    PHP和NoSQL数据库都是现今非常流行的技术,前者是一种流行的服务器端编程语言,后者则是一种非关系型数据库,主要用于处理半结构化和非结构化数据。PHP和NoSQL数据库分别在不同领域得到了广泛应用,但它们之间的对比究竟能够如何呢?本文将对...
    99+
    2023-05-15
    PHP NoSQL数据库 对比
  • Python ORM 与 NoSQL 数据库的比较:选择最佳工具
    对象关系映射(ORM)是一种用于将对象模型与关系数据库进行映射的技术,而 NoSQL(非关系型)数据库是专为非结构化或半结构化数据的存储和检索而设计的。 目标受众 Python ORM 主要面向使用关系数据库的 Python 开发人员,而...
    99+
    2024-03-15
    ORM
  • NoSQL数据库概览及其与SQL语法的比较是怎样的
    NoSQL数据库概览及其与SQL语法的比较是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。HBase是一个高可靠性、高性...
    99+
    2024-04-02
  • oracle数据库和mysql哪个比较好
    oracle数据库和mysql是热门选择,适合取决于特定需求。oracle提供更全面的功能、更好的性能和可扩展性,但成本较高;mysql专注于基本关系数据库功能,速度更快,但可靠性较低。...
    99+
    2024-05-10
    mysql oracle
  • MongoDB与关系型数据库的比较与迁移实践
    MongoDB与关系型数据库的比较与迁移实践随着互联网和大数据技术的快速发展,数据库技术也在不断创新和进化。一种新兴的数据库类型,NoSQL数据库,也逐渐引起了人们的关注。在NoSQL数据库中,MongoDB是一种非常受欢迎的解决方案。与传...
    99+
    2023-11-02
    MongoDB 关系型数据库 迁移实践
  • mysql和oracle哪个数据库比较好用
    这篇文章主要介绍mysql和oracle哪个数据库比较好用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql和oracle哪个好?如果是中小型网站的开发首选MySQL数据库。M...
    99+
    2024-04-02
  • vbscript 中怎么比较三个数的大小
    今天就跟大家聊聊有关vbscript 中怎么比较三个数的大小,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。代码如下:dim a,b,c a =inputbox ("请输入0...
    99+
    2023-06-08
  • Python操作MySQL MongoDB Oracle三大数据库深入对比
    目录1. Python操作Oracle数据库2. Python操作MySQL数据库3. Python操作MongoDB数据库作为数据分析师,掌握一门数据库语言,是很有必要的。 今天黄...
    99+
    2024-04-02
  • redis学习之NoSQL数据四大分类的对比示例
    这篇文章主要介绍了redis学习之NoSQL数据四大分类的对比示例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。KV键值对新浪:Berkel...
    99+
    2024-04-02
  • mongodb与sql关系型数据比较的示例分析
    这篇文章给大家分享的是有关mongodb与sql关系型数据比较的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。摸索了几天,大体也初步算入了mongodb的门,仔细一想,m...
    99+
    2024-04-02
  • 常用的 NoSQL 数据库系统对比分析有哪些
    本篇内容主要讲解“常用的 NoSQL 数据库系统对比分析有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“常用的 NoSQL 数据库系统对比分析有哪些”吧!1...
    99+
    2024-04-02
  • 结构化SQL数据库与非结构化NOSQL数据库的对比是怎样的
    今天就跟大家聊聊有关结构化SQL数据库与非结构化NOSQL数据库的对比是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。大家好,我们来谈一下数据...
    99+
    2024-04-02
  • NoSQL数据库的简单介绍以及redis持久化数据服务
    本篇内容介绍了“NoSQL数据库的简单介绍以及redis持久化数据服务”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够...
    99+
    2024-04-02
  • Oracle与Sybase数据库管理系统的比较与对比
    Oracle与Sybase数据库管理系统的比较与对比 随着信息技术的迅速发展,数据库管理系统的选择变得越来越重要。在众多数据库管理系统中,Oracle和Sybase是两个备受关注的产品...
    99+
    2024-03-07
    - 比较 - oracle - sybase
  • 前一段时间比较火的刷网课平台源码,带数据库和教程
    前一段时间比较火的刷网课平台源码,带数据库和教程。 好在疫情已经结束了,希望今后世上再无网课。 这个代码免费提供给大家学习开发用吧,作为一个php的入门学习案例用用还可以。 使用办法 网站根目录解压 打开nginx.htaccess文件,复...
    99+
    2023-09-02
    数据库 php 网课 在线教育 教育电商
  • 量比较多的数据库该怎样优化
    这期内容当中小编将会给大家带来有关量比较多的数据库该怎样优化,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。查询的优化  保证在实现功能的基础上,尽量减少对数据库的访问次数...
    99+
    2024-04-02
  • 弦歌不辍,绕梁三日:NoSQL 数据库的知识点扫盲
    ...
    99+
    2024-04-02
  • NoSQL 数据库的5个优点与挑战是什么
    这篇文章主要讲解了“NoSQL 数据库的5个优点与挑战是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“NoSQL 数据库的...
    99+
    2024-04-02
  • 我们如何比较两个 MySQL 表中的数据?
    有时我们需要找出两个表中不匹配的数据,尤其是在数据迁移的情况下。可以通过比较表格来完成。考虑下面的示例,其中我们有两个名为“students”和“student1”的表。mysql> Select * from studen...
    99+
    2023-10-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作