Redis和Memcache对比

Redis和Memcache对比

名称 Redis Memcache 对比说明
性能 只使用单核 可以使用多核 Redis在存储小数据时比Memcached性能更高。而在100k以上的数据中,Memcached性能要高于Redis
内存使用率 有部份存在硬盘上,支持数据的持久化. (有快照和AOF日志两种持久化方式,在实际应用的时候,要特别注意配置文件快照参数,要不就很有可能服务器频繁满载做dump) 数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小 对于key-value这样简单的数据储存,memcache的内存使用率更高。 如果采用hash结构,redis的内存使用率会更高。
内存管理 Redis使用现场申请内存的方式来存储数据,并且很少使用free-list等方式来优化内存分配,会在一定程度上存在内存碎片,Redis跟据存储命令参数,会把带过期时间的数据单独存放在一起,并把它们称为临时数据,非临时数据是永远不会被剔除的,即便物理内存不够,导致swap也不会剔除任何非临时数据(但会尝试剔除部分临时数据),这点上Redis更适合作为存储而不是cache 使用预分配的内存池的方式,使用slab和大小不同的chunk来管理内存,Item根据大小选择合适的chunk存储,内存池的方式可以省去申请/释放内存的开销,并且能减小内存碎片产生,但这种方式也会带来一定程度上的空间浪费,并且在内存仍然有很大空间时,新的数据也可能会被剔除 memcache把内存分成很多种规格的存储块,有块就有大小,这种方式也就决定了,memcache不能完全利用内存,会产生内存碎片,如果存储块不足,还会产生内存溢出。
数据支持类型 不仅仅支持简单的k/v类型的数据,同时还提供list,set,zset,hash等 k/v类型,不支持枚举,不支持持久化和复制 redis在数据支持上要比memecache多的多
数据一致性 Redis没有提供cas 命令,并不能保证这点,不过Redis提供了事务的功能,可以保证一串 命令的原子性,中间不会被任何操作打断 Memcached提供了cas命令,可以保证多个并发访问操作同一份数据的一致性问题 数据一致性上两者有区别
总结 如果需要缓存的数据只是key-value这样简单的结构时,我在项目里还是采用memcache,它也足够的稳定可靠。如果涉及到存储,排序,聚合等对数据结构和处理有高级要求时,毫无疑问选择redis

你可能感兴趣的:(redis,memcache)