关于redis的某些事

1、redis使用场景,能做什么事,不方便做什么事?

2、为什么使用redis?

3、redis为什么这么快?

  • 纯内存数据库,和cpu交互快
  • 单线程操作,避免了上下文切换和避免了一些锁的判断机制
  • 采用了非阻塞I/O多路复用机制
  • 数据结构简单

4、redis缓存和数据库数据一致性问题

先删除缓存,然后更新数据库

5、如何应对缓存穿透和缓存雪崩问题以及缓存击穿

缓存穿透,即黑客故意去请求缓存中不存在的数据,导致所有的请求都怼到数据库上,从而数据库连接异常。

解决方案:
(一)利用互斥锁,缓存失效的时候,先去获得锁,得到锁了,再去请求数据库。没得到锁,则休眠一段时间重试
(二)采用异步更新策略,无论key是否取到值,都直接返回。value值中维护一个缓存失效时间,缓存如果过期,异步起一个线程去读数据库,更新缓存。需要做缓存预热(项目启动前,先加载缓存)操作。
(三)提供一个能迅速判断请求是否有效的拦截机制,比如,利用布隆过滤器,内部维护一系列合法有效的key。迅速判断出,请求所携带的Key是否合法有效。如果不合法,则直接返回。

缓存雪崩,即缓存同一时间大面积的失效,这个时候又来了一波请求,结果请求都怼到数据库上,从而导致数据库连接异常。

解决方案:
(一)给缓存的失效时间,加上一个随机值,避免集体失效。
(二)使用互斥锁,但是该方案吞吐量明显下降了。
(三)双缓存。我们有两个缓存,缓存A和缓存B。缓存A的失效时间为20分钟,缓存B不设失效时间。自己做缓存预热操作。然后细分以下几个小点

  • I 从缓存A读数据库,有则直接返回

  • II A没有数据,直接从B读数据,直接返回,并且异步启动一个更新线程。

  • III 更新线程同时更新缓存A和缓存B。

缓存击穿,缓存击穿,是指一个key非常热点,在不停的扛着大并发,大并发集中对这一个点进行访问,当这个key在失效的瞬间,持续的大并发就穿破缓存,直接请求数据库,就像在一个屏障上凿开了一个洞。

key设置不过期

6、如何解决redis的并发竞争key问题?

  • redis事务机制
  • redis分布式锁
  • zookeeper分布式锁

7、redis的过期策略和内存淘汰机制

我们set key的时候,都可以给一个expire time,就是过期时间,指定这个key比如说只能存活1个小时,我们自己可以指定缓存到期就失效。

如果假设你设置一个一批key只能存活1个小时,那么接下来1小时后,redis是怎么对这批key进行删除的?

答案是:定期删除+惰性删除

所谓定期删除,指的是redis默认是每隔100ms就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除。

注意,这里可不是每隔100ms就遍历所有的设置过期时间的key,那样就是一场性能上的灾难。

实际上redis是每隔100ms随机抽取一些key来检查和删除的。

但是,定期删除可能会导致很多过期key到了时间并没有被删除掉,所以就得靠惰性删除了。

这就是说,在你获取某个key的时候,redis会检查一下 ,这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删除,不会给你返回任何东西。

并不是key到时间就被删除掉,而是你查询这个key的时候,redis再懒惰的检查一下

通过上述两种手段结合起来,保证过期的key一定会被干掉。

但是实际上这还是有问题的,如果定期删除漏掉了很多过期key,然后你也没及时去查,也就没走惰性删除,此时会怎么样?

如果大量过期key堆积在内存里,导致redis内存块耗尽了,怎么办?

答案是:走内存淘汰机制。

内存淘汰机制:

如果redis的内存占用过多的时候,此时会进行内存淘汰,有如下一些策略:

noeviction:当内存不足以容纳新写入数据时,新写入操作会报错,这个一般没人用吧

allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的key(这个是最常用的)

allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个key,这个一般没人用吧

volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的key(这个一般不太合适)

volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个key

volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的key优先移除

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用Spring Session Redis时,您可以通过配置`spring.session.redis.filter-dispatcher-types`属性来排除某些路径。该属性指定了一个逗号分隔的字符串列表,其中包含要排除的请求类型。 默认情况下,Spring Session Redis会拦截所有请求并将它们重定向到一个新的URL。如果您想要排除某些路径,您可以在`application.properties`或`application.yml`文件中添加以下配置: ``` spring.session.redis.filter-dispatcher-types=REQUEST,ASYNC ``` 在此示例中,我们排除了所有普通请求和异步请求。您可以根据需要修改该属性,以排除其他类型的请求。注意,这些请求将不会使用Spring Session Redis进行会话管理。 如果您使用的是Java配置方式,可以使用以下代码: ``` @Configuration public class SessionConfig { @Bean public RedisOperationsSessionRepository sessionRepository(RedisConnectionFactory redisConnectionFactory) { RedisOperationsSessionRepository sessionRepository = new RedisOperationsSessionRepository(redisConnectionFactory); sessionRepository.setFilterDispatcherTypes(EnumSet.of(DispatcherType.REQUEST, DispatcherType.ASYNC)); return sessionRepository; } } ``` 在这种情况下,我们排除了所有普通请求和异步请求。同样,您可以根据需要修改此配置。 请注意,如果您排除了一些请求类型,这些请求将不会使用Spring Session Redis进行会话管理。因此,您需要确保这些请求不会影响应用程序的会话管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值