Redis 和 Memcache 区别

数据结构
Redis支持多种数据结构,String、Set、List、Hash、SortedSet。
Memcached基本只支持简单的key-value存储,不支持枚举,不支持持久化和复制等功能。

内存管理
Memcached使用预分配的内存池的方式,使用slab和大小不同的chunk来管理内存,Item根据大小选择合适的chunk存储,内存池的方式可以省去申请/释放内存的开销,并且能减小内存碎片产生,但这种方式也会带来一定程度上的空间浪费,并且在内存仍然有很大空间时,新的数据也可能会被剔除。

Redis使用现场申请内存的方式来存储数据,并且很少使用free-list等方式来优化内存分配,会在一定程度上存在内存碎片,Redis跟据存储命令参数,会把带过期时间的数据单独存放在一起,并把它们称为临时数据,非临时数据是永远不会被剔除的,即便物理内存不够,导致swap也不会剔除任何非临时数据(但会尝试剔除部分临时数据),这点上Redis更适合作为存储而不是cache。Redis当物理内存用完时,可以将一些很久没用到的value 交换到磁盘。

网络模型
Redis使用单线程的IO复用模型,自己封装了一个简单的AeEvent事件处理框架,主要实现了epoll、kqueue和select,对于单纯只有IO操作来说,单线程可以将速度优势发挥到最大,但是Redis也提供了一些简单的计算功能,比如排序、聚合等,对于这些操作,单线程模型实际会严重影响整体吞吐量,CPU计算过程中,整个IO调度都是被阻塞住的。

Memcache是多线程,非阻塞IO复用的网络模型,分为监听主线程和worker子线程,监听线程监听网络连接,接受请求后,将连接描述字pipe 传递给worker线程,进行读写IO, 网络层使用libevent封装的事件库,多线程模型可以发挥多核作用,但是引入了cache coherency和锁的问题,比如,Memcache最常用的stats 命令,实际Memcache所有操作都要对这个全局变量加锁,进行计数等工作,带来了性能损耗。

备份恢复、持久化、灾后重建
Redis支持数据的备份,即master-slave模式的数据备份;redis可以定期保存到磁盘(持久化);redis数据丢失后可以通过aof/rdb恢复。
Memcache挂掉后,数据不可恢复。

应用场景
Redis出来作为NoSQL数据库使用外,还能用做消息队列、数据堆栈和数据缓存等;
Memcached适合于缓存SQL语句、数据集、用户临时性数据、延迟查询数据和session等。

你可能感兴趣的:(Redis 和 Memcache 区别)