时间:2021-05-19
我们使用redis是为了减少数据库的压力,让尽量多的请求去承压能力比较大的redis,而不是数据库。但是高并发条件下,可能会在redis还没有缓存的时候,大量的请求同时进入,导致一大批的请求直奔数据库,而不会经过redis。使用代码模拟缓存穿透问题如下:
首先是service里面的代码:
@Servicepublic class NewsService { @Autowired private NewsDAO newsDAO; //springboot自动初始化,不需要我们进行配置,直接注入到代码中使用 @Autowired private RedisTemplate<Object,Object> redisTemplate; public List<News> getLatestNews(int userId,int offset,int limit){ //设置序列化方式,防止乱码 redisTemplate.setKeySerializer(new StringRedisSerializer()); //第一步:查询缓存 News news= (News) redisTemplate.opsForValue().get("newsKey"); //判断是否存在缓存 if(null == news){//查询数据库 news = newsDAO.selectByUserIdAndOffset(userId,offset,limit).get(0); // redisTemplate.opsForValue().set("newsKey",news); System.out.println("进入数据库。。。。。。。。"); }else{ System.out.println("进入缓存。。。。。。。。。"); } return newsDAO.selectByUserIdAndOffset(userId,offset,limit); }}然后是使用线程池在Controller里面对请求进行模拟:
@Controllerpublic class HomeController { @Autowired UserService userService; @Autowired NewsService newsService; //遇到的坑,如果不加method,页面启动不起来。 @RequestMapping(value = "/home",method = {RequestMethod.GET, RequestMethod.POST}) @ResponseBody public String index(Model model){ //这边是可以读出数据来的 //线程池------缓存穿透问题的复现 ExecutorService executorService = Executors.newFixedThreadPool(8*2); for(int i = 0;i < 50000;i++){ executorService.submit(new Runnable() { @Override public void run() { List<News> newsList = newsService.getLatestNews(0,0,10); } }); } List<News> newsList = newsService.getLatestNews(0,0,10); News news=newsList.get(0); return news.getImage(); }}结果如图:大量的请求进入数据库,那么如何解决这个问题?
直接在方法上加锁,保证每次只有一个请求可以进入。但是这个方法存在一个缺陷,每次只有一个请求可以进入,请求处理的速度变得相当的慢,不利于系统的实时性。
这个方法比较好,虽然不能保证只有一个请求请求数据库,但是当第一批请求进来,第二批之后的所有请求全部会在缓存取数据。
到此这篇关于springboot中redis的缓存穿透问题实现的文章就介绍到这了,更多相关springboot redis缓存穿透内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言作为Java程序员,在面试过程中,缓存相关的问题是躲不掉的,肯定会问,例如缓存一致性问题,缓存雪崩、击穿、穿透等。说到缓存,那肯定少不了Redis,我在面试
什么叫做缓存穿透缓存穿透只会发生在高并发的时候,就是当有10000个并发进行查询数据的时候,我们一般都会先去redis里面查询进行数据,但是如果redis里面没
redis缓存知识点:一、缓存穿透缓存穿透是指查询一个缓存和数据库中都没有的数据,由于大部分缓存策略是被动加载的,并且出于容错考虑,如果从存储层查不到数据则不写
在上一节中,我带大家学习了详解SpringBoot集成Redis来实现缓存技术方案,尤其是结合SpringCache的注解的实现方案,接下来在本章节中,我带大家
因项目集成了Redis缓存部分数据,需要在程序启动时将数据加载到Redis中,即初始化数据到Redis。在SpringBoot项目下,即在容器初始化完毕后执行我