1.为什么要用redis而不用map做缓存?
缓存分为本地缓存和分布式缓存。
- 在Java中,使用自带的map或者guava实现的是本地缓存。最主要的特点是轻量以及快速,生命周期随着JVM的销毁而结束。并且在多实例的情况下,每个实例都需要各自保存一份缓存,缓存不具有一致性。
- 使用redis,这种叫做分布式缓存。在多实例的情况下,各实例共用一份缓存,缓存具有一致性。缺点是要保持redis服务的高可用,整个程序框架较为复杂。
——————————————————————————————————————————
1.Redis可用几十个G内存来做缓存,Map中JVM一般最大也就分几个G。
2.Redis的缓存可以持久化,Map是内存对象,程序一重启数据就没有了,
3.Redis可以实现分布式缓存,Map只能存在创建它的程序里。
4.Redis可以每秒处理百万级的并发,是专业的缓存服务,Map只是一个普通的对象。
5.Redis缓存有过期机制,Map本身无此功能。
6**.Redis有丰富的API**,Map就简单太多了。
—————————————————————————————————————————— - Redis可以独立部署,这样网站代码更新后Redis缓存的数据还在; 本地内存每次网站更新后都会释放掉。
- Redis多个项目间可以共享数据,但是本地内存无法跨项目共享。
2. redis 和 memcached 的区别
现在公司一般都是用 redis 来实现缓存,而且 redis 自身也越来越强大了!
- redis 支持更丰富的数据类型(支持更复杂的应用场景):
1.redis不仅仅支持简单的K/V类型的数据,同时还提供list,set,zset,hash等数据结构的储存。
2.memcahed只支持String数据类型。 - redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用;而Memecache把数据全部储存在内存之中。
- 集群模式:Memcached没有原生的集群模式,需要依靠客户端来实现往集群中分片写入数据;但是redis目前是支持原生的集群模式的。
Memcached是多线程,非阻塞IO复用网络模型;Redis使用单线程的多路IO复用模型(原子性);