Redis和MongoDB区别
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开始支持集群。
上一篇: 一 Java基础知识
下一篇: 微信小程序实现手势图案锁屏功能
推荐阅读
-
@ResponseBody 和 @RequestBody 注解的区别
-
苹果全新MacBook Pro 13和15寸哪个值得买?新MacBook Pro13/15英寸深度对比区别评测
-
ABBYY FineReader简体中文版和多语言专业版有什么区别?
-
小米笔记本Air和小新Air Pro哪个好?小米笔记本Air和联想小新Air Pro详细区别对比评测
-
系统32位和64位的区别 Windows系统32位和64位的区别在哪里
-
封装app是什么意思,盘点封装app和原生app的区别
-
SQL 中having 和where的区别分析
-
Python redis操作实例分析【连接、管道、发布和订阅等】
-
Python中print和return的作用及区别解析
-
锆石是什么材质?和砖石又什么区别