Redis 和 MongoDB 的优缺点??

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

Redis 优点:

a) 读写性能优异

b) 支持数据持久化,支持 AOF 和 RDB 两种持久化方式

c) 支持主从复制,主机会自动将数据同步到从机,可以进行读写分离。

d) 数据结构丰富:数据结构丰富:支持 string、hash、set、sortedset、list 等数据结构。

缺点:

e) Redis 不具备自动容错和恢复功能,主机从机的宕机都会导致前端部分读写请求失败,需要 等待机器重启或者手动切换前端的 IP 才能恢复。

f) 主机宕机,宕机前有部分数据未能及时同步到从机,切换 IP 后还会引入数据不一致的问题, 降低了系统的可用性。

h) Redis 较难支持在线扩容,在集群容量达到上限时在线扩容会变得很复杂。为避免这一问题, 运维人员在系统上线时必须确保有足够的空间,这对资源造成了很大的浪费。

MongoDB 优点:

a)弱一致性(最终一致),更能保证用户的访问速度

b)文档结构的存储方式,能够更便捷的获取数

c)内置 GridFS,高效存储二进制大对象 (比如照片和视频)

d)支持复制集、主备、互为主备、自动分片等特性

e)动态查询

f)全索引支持,扩展到内部对象和内嵌数组

缺点:

a)不支持事务

b)MongoDB 占用空间过大

c)维护工具不够成熟

猜你喜欢

转载自www.cnblogs.com/lmh001/p/9747218.html