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