redis和mongoDB的区别

Redis

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

支持持久化操作,可以进行aof及rdb数据持久化到磁盘,从而进行数据备份或数据恢复等操作,较好的防止数据丢失的字段。
支持数据复制,支持多级复制和增量复制。
支持简单的事务请求,但业界使用场景很少,并不成熟。

  • redis 的局限性:

redis只能使用单线程,性能受限于cpu性能,故单实例cpu最高才能达到5-6wQPS/s, 这取决于数据结构,数据大小以及服务器硬件性能,日常环境中QPS高峰大约在1-2w左右)。redis在string类型上会消耗较多内存,可以使用dict(hash表)压缩存储以及降低内存耗用。

不适合在不同数据集之间建立关系,也不适合进行查询搜索,就像灾难。

mongoDB:

是一种文档型的数据库,即:可以存放xml,json,bson,关系型的数据。

  • 这些数据具备自述性(self-describing),呈现分层的树状数据结构,redis可以用hash存放简单关系型数据。
  • mongodb存放json格式数据。
  • 适合场景:事件记录,内容管理或博客平台,比如评论系统。
  • 持久化原理:mongodb与mysql不同,mysql的每一次更新操作都会直接写入硬盘,但是mongodb不会,作为内存型数据库,数据会先写入内存,然后再会持久化到硬盘中去,那么mongodb是如何持久化的呢,mongodb在启动时,专门初始化一个线程不断循环(除非应用crash掉),用于在一定时间周期内来defer(延迟)队列中获取要持久化的数据并写入到磁盘的日志和数据处,当进行CURD操作时,记录(Record类型)都被列入到defer队列中以供延时批量(gruopcommit)提交写入,但相信其中的时间周期参数是个要认真考量的参数,系统为90毫秒,如果该值更低的话,可能会造成频繁的磁盘操作,过高又会造成系统宕机时数据丢失。

MySQL和MongoDB之间最基本的区别是什么?

  • 关系型数据库与非关系型数据库的区别,即数据存储结构的不同。 MongoDB的特点是什么?

1.面向文档 2.高性能 3.高可用 4.易扩展 5.丰富的查询语言 6.支持存储过程 7.是javascript写的

应用场景:
redis:数据量较小的高性能操作和运算上
MongoDB:主要解决海量数据的访问效率问题

你可能感兴趣的:(redis和mongoDB的区别)