Redis总结篇1

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复用模型(原子性);
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值