浅谈MongoDB、MySQL以及Redis

这些数据库或多或少都听过也学过一点,随着时间的推移也忘记了许多。记得当初腾讯面试官有问过我这三者的区别,当初一脸懵逼,趁着春招面试前把这块好好总结清楚。

SQL和NoSQL

SQL,全称Structured Query Language(结构化查询语言),MySQL中的 My 则是MySQL的发明者 Michael “Monty” Widenius以他女儿的名字命名的。

MySQL和Oracle都是关系型数据库,它们有着事务的特性,但是遇到高并发的业务场景时,就需要使用缓存,NoSQL非关系型数据库就成为最佳选择。

NoSQL常见解释为non-relational非关系型数据库,也叫文档型数据库,也有的解释为Not Only SQL,它不保证事务,但可以存放xml、json、bson类型系那个的数据。这些数据具备自述性,呈现分层的树状数据结构。数据结构由键值(key=>value)对组成。最常见的就是MongoDB和Redis这两种数据库。

MySQL和MongoDB

MySQL

  1. 在不同的引擎上有不同的存储方式。MySQL拥有3种存储引擎,分别是MyISAM、InnoDB和Memory,它们的区别如下:

在这里插入图片描述

  1. 查询语句是使用传统的sql语句,拥有较为成熟的体系,成熟度很高。
  2. 开源数据库的份额在不断增加,mysql的份额页在持续增长。
  3. 缺点就是在海量数据处理的时候效率会显著变慢。

MongoDB

  1. 存储方式:虚拟内存+持久化。
  2. 查询语句:是独特的MongoDB的查询方式。
  3. 适合场景:事件的记录,内容管理或者博客平台等等。
  4. 架构特点:可以通过副本集,以及分片来实现高可用。
  5. 数据处理:数据是存储在硬盘上的,只不过需要经常读取的数据会被加载到内存中,将数据存储在物理内存中,从而达到高速读写。
  6. 成熟度与广泛度:新兴数据库,成熟度较低,Nosql数据库中最为接近关系型数据库,比较完善的DB之一,适用人群不断在增长。

MongoDB优势与劣势

优势:
1、在适量级的内存的MongoDB的性能是非常迅速的,它将热数据存储在物理内存中,使得热数据的读写变得十分快。
2、MongoDB的高可用和集群架构拥有十分高的扩展性。
3、在副本集中,当主库遇到问题,无法继续提供服务的时候,副本集将选举一个新的主库继续提供服务。
4、MongoDB的Bson和JSon格式的数据十分适合文档格式的存储与查询。

劣势:
1、 不支持事务操作。MongoDB本身没有自带事务机制,若需要在MongoDB中实现事务机制,需通过一个额外的表,从逻辑上自行实现事务。
2、 应用经验少,由于NoSQL兴起时间短,应用经验相比关系型数据库较少。
3、MongoDB占用空间过大。

MongoDB和Redis的区别是什么
明白了关系型数据库和非关系型数据库的区别,再来看看同为非关系型数据库的MongoDB和Redis的区别:

MongoDB 更类似 MySQL,支持字段索引、游标操作,其优势在于查询功能比较强大,擅长查询 JSON 数据,能存储海量数据,但是不支持事务。

Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,支持多种类型的数据结构,可用作数据库,高速缓存和消息队列代理。

1、内存管理机制

Redis 数据全部存在内存,定期写入磁盘,当内存不够时,可以选择指定的 LRU 算法删除数据。

MongoDB 数据存在内存,由 linux系统 mmap 实现,当内存不够时,只将热点数据放入内存,其他数据存在磁盘。

2、支持的数据结构

Redis 支持的数据结构丰富,包括hash、set、list等。

MongoDB 数据结构比较单一,但是支持丰富的数据表达,索引,最类似关系型数据库,支持的查询语言非常丰富。

3、数据量和性能:

当物理内存够用的时候,redis>mongodb>mysql

当物理内存不够用的时候,redis和mongodb都会使用虚拟内存。

实际上如果redis要开始虚拟内存,那很明显要么加内存条,要么你换个数据库了。

但是,mongodb不一样,只要,业务上能保证,冷热数据的读写比,使得热数据在物理内存中,mmap的交换较少。

mongodb还是能够保证性能。

4、性能

mongodb依赖内存,TPS较高;Redis依赖内存,TPS非常高。性能上Redis优于MongoDB。

5、可靠性

mongodb从1.8版本后,采用binlog方式(MySQL同样采用该方式)支持持久化,增加可靠性;

Redis依赖快照进行持久化;AOF增强可靠性;增强可靠性的同时,影响访问性能。

可靠性上MongoDB优于Redis。

6、数据分析

mongodb内置数据分析功能(mapreduce);而Redis不支持。

7、事务支持情况

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

8、集群

MongoDB 集群技术比较成熟,Redis从3.0开始支持集群。

参考文章1:https://www.jianshu.com/p/56524b50b376
参考文章2:https://www.php.cn/redis/421928.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DreamYum

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值