二維碼
企資網(wǎng)

掃一掃關注

當前位置: 首頁 » 企業(yè)資訊 » 行業(yè) » 正文

接口優(yōu)化_Redis預減庫存_減少對數(shù)據(jù)庫訪問

放大字體  縮小字體 發(fā)布日期:2021-11-16 01:42:18    瀏覽次數(shù):90
導讀

Redis預減庫存:主要思路減少對數(shù)據(jù)庫得訪問,之前得減庫存,直接訪問數(shù)據(jù)庫,讀取庫存,當高并發(fā)請求到來得時候,大量得讀取數(shù)據(jù)有可能會導致數(shù)據(jù)庫得崩潰。思路:系統(tǒng)初始化得時候,將商品庫存加載到Redis 緩存中

Redis預減庫存:主要思路減少對數(shù)據(jù)庫得訪問,之前得減庫存,直接訪問數(shù)據(jù)庫,讀取庫存,當高并發(fā)請求到來得時候,大量得讀取數(shù)據(jù)有可能會導致數(shù)據(jù)庫得崩潰。

思路:

  1. 系統(tǒng)初始化得時候,將商品庫存加載到Redis 緩存中保存
  2. 收到請求得時候,現(xiàn)在Redis中拿到該商品得庫存值,進行庫存預減,如果減完之后庫存不足,直接返回邏輯Exception就不需要訪問數(shù)據(jù)庫再去減庫存了,如果庫存值正確,進行下一步
  3. 將請求入隊,立即給前端返回一個值,表示正在排隊中,然后進行秒殺邏輯,后端隊列進行秒殺邏輯,前端輪詢后端發(fā)來得請求,如果秒殺成功,返回秒殺,成功,不成功就返回失敗。

(后端請求 單線程 出隊,生成訂單,減少庫存,走邏輯)前端同時輪詢

  1. 前端顯示
第壹步:預減庫存

等Overridepublic void afterPropertiesSet() throws Exception { List<GoodsVo> goods = goodsService.getGoodsList(); if (goods == null) { return; } for (GoodsVo goodsVo : goods) { redisService.set(GoodsKey.getGoodsStock, "" + goodsVo.getId(), goodsVo.getStockCount()); isOverMap.put(goodsVo.getId(), false);//先初始化 每個商品都是false 就是還有 }}

long stock = redisService.decr(GoodsKey.getGoodsStock, "" + goodsId);if (stock < 0) { isOverMap.put(goodsId, true);//沒有庫存就設置 對應id 商品得map 為true return Result.error(CodeMsg.MIAO_SHA_NO_STOCK);}預減庫存:

1.先將所有數(shù)據(jù)讀出來,初始化到緩存中,并以 stock + goodid 得形成存入Redis,

2.在秒殺得時候,先進行預減庫存檢測,從redis中,利用decr 減去對應商品得庫存,如果庫存小于0,說明此時 庫存不足,則不需要訪問數(shù)據(jù)庫。直接拋出異常即可

內存標記:

由于接口優(yōu)化很多基于Redis得緩存操作,當并發(fā)很高得時候,也會給Redis服務器帶來很大得負擔,如果可以減少對Redis服務器得訪問,也可以達到得優(yōu)化得效果。

于是,可以加一個內存map,標記對應商品得庫存量是否還有,在訪問Redis之前,在map中拿到對應商品得庫存量標記,就可以不需要訪問Redis 就可以判斷沒有庫存了。

1.生成一個map,并在初始化得時候,將所有商品得id為鍵,標記false 存入map中。

private Map<Long, Boolean> isOverMap = new HashMap<Long, Boolean>();等Overridepublic void afterPropertiesSet() throws Exception { List<GoodsVo> goods = goodsService.getGoodsList(); if (goods == null) { return; } for (GoodsVo goodsVo : goods) { redisService.set(GoodsKey.getGoodsStock, "" + goodsVo.getId(), goodsVo.getStockCount()); isOverMap.put(goodsVo.getId(), false);//先初始化 每個商品都是false 就是還有 }} boolean isOver = isOverMap.get(goodsId); if (isOver) { return Result.error(CodeMsg.MIAO_SHA_NO_STOCK); } if (stock < 0) { isOverMap.put(goodsId, true);//沒有庫存就設置 對應id 商品得map 為true

2.在預減庫存之前,從map中取標記,若標記為false,說明庫存,還有,

3.預減庫存,當遇到庫存不足得時候,將該商品得標記置為true,表示該商品得庫存不足。這樣,下面得所有請求,將被攔截,無需訪問redis進行預減庫存。

blog.csdn/weixin_38035852/article/details/81174986

 
(文/小編)
免責聲明
本文僅代表作發(fā)布者:個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經(jīng)發(fā)現(xiàn),立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯(lián)系我們刪除處理郵件:weilaitui@qq.com。
 

Copyright ? 2016 - 2025 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號

粵ICP備16078936號

微信

關注
微信

微信二維碼

WAP二維碼

客服

聯(lián)系
客服

聯(lián)系客服:

在線QQ: 303377504

客服電話: 020-82301567

E_mail郵箱: weilaitui@qq.com

微信公眾號: weishitui

客服001 客服002 客服003

工作時間:

周一至周五: 09:00 - 18:00

反饋

用戶
反饋

主站蜘蛛池模板: 一区二区三区影院| 亚洲av无码专区国产不乱码| freehdxxx2018| 男人把女人桶爽30分钟动态| 岛国大片免费观看| 午夜小视频免费| 一级片黄色免费| 精品视频国产狼人视频| 成人品视频观看在线| 午夜羞羞视频在线观看| 一本一本久久a久久精品综合麻豆| 精品国产粉嫩内射白浆内射双马尾 | 亚洲综合色在线| 99久久精品国产亚洲| 欧美综合自拍亚洲综合图| 国产香蕉精品视频在| 国产精品美女久久久久AV福利 | 国产麻传媒精品国产AV| 亚洲欧美日韩另类在线专区| 两个小姨子完整版| 精品72久久久久久久中文字幕| 女同学下面粉嫩又紧多水| 亚洲色婷婷综合久久| 77777_亚洲午夜久久多人| 最近更新2019中文字幕8| 国产国产人免费视频成69大陆| 久久se精品一区精品二区| 美女被免费网站视频九色| 女人18片毛片60分钟| 亚洲激情视频图片| AAAA级少妇高潮大片在线观看| 精品国产青草久久久久福利| 女人双腿搬开让男人桶| 亚洲欧洲无码一区二区三区| 人人爽天天爽夜夜爽曰| 日本护士xxxx黑人巨大| 国产男女爽爽爽免费视频| 久久人爽人人爽人人片av| 精品国产一区二区三区色欲| 国内精品久久久久久久久蜜桃| 亚洲av综合av一区|