Redis是一个完全开源免费的高性能key-value数据库,它具有丰富的数据类型,可以支持数据的持久化,将内存中的数据保存在磁盘中,当重启服务器时可以再次加载使用。
Memcache是一个高性能的分布式内存对象缓存系统,用于动态的Web应用中,帮助数据库减轻负担,在内存中缓存数据和对象,减少每次访问数据时对数据库的访问次数,从而提高访问速度。
它们具有以下几点区别:
1)Redis和Memcache的最大区别是,虽然Memcache和Redis都是将数据存储在内存中,是内存数据库,但当Redis存储时,并不是所有的数据都一直存储在内存中,而Memcache存储时,数据都存储在内存中。
2)数据安全问题,由于Memcache把数据全部存在内存之中,当服务器挂掉后,重启服务器数据就会丢失,而Redis可以定期保存数据到磁盘中做持久化存储,当需要时可以再加载使用。对于灾难恢复,当Memcache挂掉后,数据不可恢复,但Redis数据丢失后可以通过aof恢复。
3)Redis支持多种数据结构存储,例如list、set、hash等数据结构的存储,而Memcache主要是在内存中维护一个统一的巨大的hash表进行存储数据,它只支持简单的key/value类型的数据存储,但它可以存储图片、视频、文件及数据库检索结果等。
4)数据备份问题,Redis支持数据的备份,即master-slave模式的数据备份。而因为Memcache不支持数据持久化,所以无法进行数据备份。
5)在内存使用率上,如果使用简单的key-value存储,则Memcache的内存利用率更高,而如果Redis采用hash结构来做key-value存储,则由于其组合式的压缩,其内存利用率会高于Memcache。具体和应用场景、数据特性有关。
6)在线程上的比较,因为Memcache是支持多线程的,而Redis只支持单线程,所以CPU利用方面Memcache优于Redis。
7)它们的扩展都需要做集群,实现方式:master-slave、Hash。
8)数据的读写方面,Redis和Memcache在写入性能上面差别不大,读取性能上面尤其是批量读取性能上Memcache更强。