Redis 和 Memcache 相比较优缺点的不同区别是什么

目前 Memcache(Memcached)和 Redis 都有很多的使用者,那么两者之间有什么区别,自己该如何选择呢?本文就简单说说 Redis 和 Memcache 相比较优缺点的不同区别是什么

Redis和Memcache区别

Redis

优点

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

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

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

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

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

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

缺点

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

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

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

 

Memcache

优点

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

2. 支持直接配置为 session handle。

缺点

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

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

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

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

 

Redis 和 Memcache 的区别有哪些

1. 性能

性能都比较高,总的来讲:Memcache 和 Redis 差不多。

2. 便利性

memcache 数据结构单一。

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

3. 存储空间

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

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

4. 可用性

redis 依赖客户端来实现分布式读写;主从复制时,每次从节点重新连接主节点都要依赖整个快照,无增量复制,因性能和效率问题,所以单点问题比较复杂;不支持自动 sharding, 需要依赖程序设定一致 hash 机制。

一种替代方案是,不用 redis本身的复制机制,采用自己做主动复制(多份存储),或者改成增量复制的方式(需要自己实现),一致性问题和性能的权衡。

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

5. 可靠性

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

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

6. 一致性

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

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

7. 应用场景

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

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

 

总结,Redis 相比 memcache(memcached) 有哪些优势?

(1) memcached 所有的值均是简单的字符串,redis 作为其替代者,支持更为丰富的数据类型

(2) redis 的速度比 memcached 快很多

(3) redis 可以持久化数据

(4) Redis 支持数据的备份,即 master-slave 模式的数据备份。

(5) 使用底层模型不同

它们之间底层实现方式 以及与客户端之间通信的应用协议不一样。

Redis 直接自己构建了 VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。

(6) value大小:redis 最大可以达到 1GB,而 memcache 只有 1MB

 

转载请注明链接地址:荐爱小站 » Redis 和 Memcache 相比较优缺点的不同区别是什么

赞 (3) 赏 !

觉得文章有用就打赏一下吧,赠人玫瑰手有余香!

支付宝扫一扫打赏

微信扫一扫打赏