<strike id="ca4is"><em id="ca4is"></em></strike>
  • <sup id="ca4is"></sup>
    • <s id="ca4is"><em id="ca4is"></em></s>
      <option id="ca4is"><cite id="ca4is"></cite></option>
    • 二維碼
      企資網

      掃一掃關注

      當前位置: 首頁 » 企業資訊 » 行業 » 正文

      接口優化_Redis預減庫存_減少對數據庫訪問

      放大字體  縮小字體 發布日期:2021-11-16 01:42:18    瀏覽次數:100
      導讀

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

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

      思路:

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

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

      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.先將所有數據讀出來,初始化到緩存中,并以 stock + goodid 得形成存入Redis,

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

      內存標記:

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

      于是,可以加一個內存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

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

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

      粵ICP備16078936號

      微信

      關注
      微信

      微信二維碼

      WAP二維碼

      客服

      聯系
      客服

      聯系客服:

      在線QQ: 303377504

      客服電話: 020-82301567

      E_mail郵箱: weilaitui@qq.com

      微信公眾號: weishitui

      客服001 客服002 客服003

      工作時間:

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

      反饋

      用戶
      反饋

      午夜久久久久久网站,99久久www免费,欧美日本日韩aⅴ在线视频,东京干手机福利视频
        <strike id="ca4is"><em id="ca4is"></em></strike>
      • <sup id="ca4is"></sup>
        • <s id="ca4is"><em id="ca4is"></em></s>
          <option id="ca4is"><cite id="ca4is"></cite></option>
        • 主站蜘蛛池模板: 欧美伊久线香蕉线新在线| 妇女bbbb插插插视频| 欧美日韩一区二区综合在线视频 | 欧美视频在线观看免费最新| 日本视频在线免费| 国色天香网在线| 国产精品91av| 午夜无遮挡羞羞漫画免费| 亚洲fuli在线观看| 亚洲另类欧美综合久久图片区| 中文字幕中文字字幕码一二区| 2018国产大陆天天弄| 精品欧美一区二区精品久久| 欧美xxxx网站| 大地资源在线资源免费观看| 国产一卡2卡3卡4卡网站免费| 亚洲国产精品成人久久| yy6080理aa级伦大片一级毛片| 高潮毛片无遮挡高清免费视频| 欧美色欧美亚洲高清在线观看| 国产麻传媒精品国产AV| 全免费a级毛片免费看| 久久国产乱子伦免费精品| 1024手机在线播放视频| 男和女一起怼怼怼30分钟| 日本亚洲娇小与非洲黑人tube| 国产精品伦一区二区三级视频| 人妻影音先锋啪啪av资源| 中文字幕无码日韩欧毛| 成年美女黄网站色大片图片| 波多野结衣中文字幕在线视频| 成人毛片免费看| 国产亚洲sss在线播放| 亚洲人和日本人jizz| 6080午夜乱理伦片| 狠狠色噜噜狠狠狠狠97| 成人AAA片一区国产精品| 国产一级在线观看| 一本色道久久综合亚洲精品高清| 自拍偷在线精品自拍偷| 欧美日韩在线观看一区二区|