av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

springboot中redis的緩存穿透問題實(shí)現(xiàn)

瀏覽:3日期:2023-03-25 17:00:02
什么是緩存穿透問題??

我們使用redis是為了減少數(shù)據(jù)庫的壓力,讓盡量多的請求去承壓能力比較大的redis,而不是數(shù)據(jù)庫。但是高并發(fā)條件下,可能會在redis還沒有緩存的時候,大量的請求同時進(jìn)入,導(dǎo)致一大批的請求直奔數(shù)據(jù)庫,而不會經(jīng)過redis。使用代碼模擬緩存穿透問題如下:

首先是service里面的代碼:

@Servicepublic class NewsService { @Autowired private NewsDAO newsDAO; //springboot自動初始化,不需要我們進(jìn)行配置,直接注入到代碼中使用 @Autowired private RedisTemplate<Object,Object> redisTemplate; public /*synchronized*/ List<News> getLatestNews(int userId,int offset,int limit){ //設(shè)置序列化方式,防止亂碼 redisTemplate.setKeySerializer(new StringRedisSerializer()); //第一步:查詢緩存 News news= (News) redisTemplate.opsForValue().get('newsKey'); //判斷是否存在緩存 if(null == news){//查詢數(shù)據(jù)庫news = newsDAO.selectByUserIdAndOffset(userId,offset,limit).get(0);//redisTemplate.opsForValue().set('newsKey',news);System.out.println('進(jìn)入數(shù)據(jù)庫。。。。。。。。'); }else{ System.out.println('進(jìn)入緩存。。。。。。。。。'); } return newsDAO.selectByUserIdAndOffset(userId,offset,limit); }}

然后是使用線程池在Controller里面對請求進(jìn)行模擬:

@Controllerpublic class HomeController { @Autowired UserService userService; @Autowired NewsService newsService; //遇到的坑,如果不加method,頁面啟動不起來。 @RequestMapping(value = '/home',method = {RequestMethod.GET, RequestMethod.POST}) @ResponseBody public String index(Model model){ //這邊是可以讀出數(shù)據(jù)來的 //線程池------緩存穿透問題的復(fù)現(xiàn) ExecutorService executorService = Executors.newFixedThreadPool(8*2); for(int i = 0;i < 50000;i++){ executorService.submit(new Runnable() {@Overridepublic 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(); }}

結(jié)果如圖:大量的請求進(jìn)入數(shù)據(jù)庫,那么如何解決這個問題?

springboot中redis的緩存穿透問題實(shí)現(xiàn)

方法一、在方法上加鎖:

@Servicepublic class NewsService { @Autowired private NewsDAO newsDAO; //springboot自動初始化,不需要我們進(jìn)行配置,直接注入到代碼中使用 @Autowired private RedisTemplate<Object,Object> redisTemplate; //第一種方式:方法加鎖 public synchronized List<News> getLatestNews(int userId,int offset,int limit){ //設(shè)置序列化方式,防止亂碼 redisTemplate.setKeySerializer(new StringRedisSerializer()); //第一步:查詢緩存 News news= (News) redisTemplate.opsForValue().get('newsKey'); //判斷是否存在緩存 if(null == news){//查詢數(shù)據(jù)庫news = newsDAO.selectByUserIdAndOffset(userId,offset,limit).get(0);//redisTemplate.opsForValue().set('newsKey',news);System.out.println('進(jìn)入數(shù)據(jù)庫。。。。。。。。'); }else{ System.out.println('進(jìn)入緩存。。。。。。。。。'); } return newsDAO.selectByUserIdAndOffset(userId,offset,limit); }}

直接在方法上加鎖,保證每次只有一個請求可以進(jìn)入。但是這個方法存在一個缺陷,每次只有一個請求可以進(jìn)入,請求處理的速度變得相當(dāng)?shù)穆?,不利于系統(tǒng)的實(shí)時性。

方法二、使用雙重校驗(yàn)鎖:

@Servicepublic class NewsService { @Autowired private NewsDAO newsDAO; //springboot自動初始化,不需要我們進(jìn)行配置,直接注入到代碼中使用 @Autowired private RedisTemplate<Object,Object> redisTemplate; //第一種方式:方法加鎖 public /*synchronized*/ List<News> getLatestNews(int userId,int offset,int limit){ //設(shè)置序列化方式,防止亂碼 redisTemplate.setKeySerializer(new StringRedisSerializer()); //第一步:查詢緩存 News news= (News) redisTemplate.opsForValue().get('newsKey'); //判斷是否存在緩存 if(null == news){ //第二種方式:雙重檢測鎖 synchronized (this){//查詢數(shù)據(jù)庫news = newsDAO.selectByUserIdAndOffset(userId,offset,limit).get(0);//redisTemplate.opsForValue().set('newsKey',news);System.out.println('進(jìn)入數(shù)據(jù)庫。。。。。。。。'); } }else{ System.out.println('進(jìn)入緩存。。。。。。。。。'); } return newsDAO.selectByUserIdAndOffset(userId,offset,limit); }}

這個方法比較好,雖然不能保證只有一個請求請求數(shù)據(jù)庫,但是當(dāng)?shù)谝慌埱筮M(jìn)來,第二批之后的所有請求全部會在緩存取數(shù)據(jù)。

到此這篇關(guān)于springboot中redis的緩存穿透問題實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)springboot redis緩存穿透內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 色天堂影院 | 不卡中文字幕 | 欧美区日韩区 | 五月婷婷综合在线 | 一级a毛片 | 亚洲精品视频在线播放 | 黄色小视频免费看 | 亚洲欧美一区二区三区在线 | 久久久久久久国产精品 | 国产美女视频网站 | 四虎8848精品成人免费网站 | 一级大片免费看 | 97免费在线视频 | 麻豆精品一区 | 日韩精品在线一区 | 91亚洲国产成人久久精品网站 | 青青草手机在线视频 | 日本在线看 | 国产a久久麻豆入口 | 精品久久久久久久 | 天天综合影院 | 麻豆精品一区 | 久久久www成人免费精品 | 人人爽人人爽 | 精品久久久久久久久久 | 国产成人99久久亚洲综合精品 | 黄片毛片在线观看 | 亚洲少妇一区 | 国产精品手机在线 | 黄色在线免费网站 | 成人免费看片39 | 日韩三级一区 | 国产免费91 | www.夜夜| 久久久久久黄色 | 国产成人精 | 亚洲二区视频 | 97在线超碰| 国产在线观看一区 | 国产成年人视频 | 国产亚洲精品成人av久久ww |