欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis高并發(fā)場景下秒殺超賣解決方案(秒殺場景)

 更新時間:2022年04月12日 10:20:36   作者:趙廣陸  
早起的12306購票,剛被開發(fā)出來使用的時候,12306會經(jīng)常出現(xiàn)超賣 這種現(xiàn)象,也就是說車票只剩10張了,卻被20個人買到了,這種現(xiàn)象就是超賣,今天通過本文給大家介紹Redis高并發(fā)場景下秒殺超賣解決方案,感興趣的朋友一起看看吧

1 什么是秒殺

秒殺最直觀的定義:在高并發(fā)場景下而下單某一個商品,這個過程就叫秒殺

【秒殺場景】

  • 火車票搶票
  • 雙十一限購商品
  • 熱度高的明星演唱會門票

2 為什么要防止超賣

早起的12306購票,剛被開發(fā)出來使用的時候,12306會經(jīng)常出現(xiàn) 超賣 這種現(xiàn)象,也就是說車票只剩10張了,卻被20個人買到了,這種現(xiàn)象就是超賣!

還有在高并發(fā)的情況下,如果說沒有一定的保護(hù)措施,系統(tǒng)會被這種高流量造成宕機(jī)

  • 庫存100件 你賣了1000件 等著虧錢吧!
  • 防止黑客
  • 假如我們網(wǎng)站想下發(fā)優(yōu)惠給群眾,但是被黑客利用技術(shù)將下發(fā)給群眾的利益收入囊中
  • 保證用戶體驗(yàn)
  • 高并發(fā)場景下,網(wǎng)頁不能打不開、訂單不能支付 要保證網(wǎng)站的使用!

3 單體架構(gòu)常規(guī)秒殺

3.1 常規(guī)減庫存代碼

/**
 * @Author oldlu
 */
@Service
@Transactional  //控制事務(wù)
public class OrderServiceImpl implements OrderService {

    @Autowired
    private StockMapper stockMapper;

    private OrderMapper orderMapper;

    //在非并發(fā)情況下無問題
    @Override
    public Integer kill(Integer id) {
        //根據(jù)商品id校驗(yàn)庫存是否還存在
        Stock stock = stockMapper.checkStock(id);
        //當(dāng)已售和庫存相等就庫存不足了
        if(stock.getSale().equals(stock.getCount())){
            throw new RuntimeException("庫存不足!");
        }else{
            //扣除庫存  (已售數(shù)量+1)
            stock.setSale(stock.getSale()+1);
            stockMapper.updateSale(stock);   //更新信息
            //創(chuàng)建訂單
            Order order = new Order();
            order.setSid(stock.getId()).setName(stock.getName()).setCreateDate(new Date());
            orderMapper.createOrder(order); //創(chuàng)建訂單
            return order.getId();   //mybatis主鍵生成策略 直接返回創(chuàng)建的id
        }
    }
}

測試controller

/**
 * @Author oldlu
 */
@RestController
@RequestMapping("/stock")
public class StockController {
    @Autowired
    private OrderService orderService;
    //開發(fā)秒殺方法
    @GetMapping("/kill/{id}")
    public String kill(@PathVariable("id") Integer id){
        System.out.println("秒殺商品的ID=====================>"+id);
        try {
            //根據(jù)秒殺商品id調(diào)用秒殺業(yè)務(wù)
            Integer orderId = orderService.kill(id);
            return "秒殺成功,訂單ID為:"+String.valueOf(orderId);
        }catch (Exception e){
            e.printStackTrace();
            return e.getMessage();
        }
    }
}

正常情況看不會有什么問題,就是你訪問一下庫存少一個

3.2 模擬高并發(fā)

3.3 超賣現(xiàn)象

3.4 分析原因

線程不安全,方法就是加鎖,單機(jī)簡單加鎖即可解決,如果是分布式集群模式搭建那就要考慮分布式鎖

4 簡單實(shí)現(xiàn)悲觀樂觀鎖解決單體架構(gòu)超賣

4.1 悲觀鎖

/**
 * @Author oldlu
 */
@RestController
@RequestMapping("/stock")
public class StockController {

    @Autowired
    private OrderService orderService;

    //開發(fā)秒殺方法
    @GetMapping("/kill/{id}")
    public String kill(@PathVariable("id") Integer id){
        System.out.println("秒殺商品的ID=====================>"+id);
        try {
            //使用悲觀鎖
            synchronized (this){
                //根據(jù)秒殺商品id調(diào)用秒殺業(yè)務(wù)
                Integer orderId = orderService.kill(id);
                return "秒殺成功,訂單ID為:"+String.valueOf(orderId);
            }
        }catch (Exception e){
            e.printStackTrace();
            return e.getMessage();
        }
    }

}

這樣效率很差會造成線程阻塞,線程排隊(duì)問題,對用戶的體驗(yàn)不是很好,必須處理完一個才能繼續(xù).

4.2 樂觀鎖

    /**
     * 扣除庫存
     * @param stock
     */
    public void updateSale(Stock stock){
        //扣除庫存  (已售數(shù)量+1)
        stock.setSale(stock.getSale()+1);
        stockMapper.updateSale(stock);   //更新信息
    }

/**
 * 扣除庫存
 * @param stock
 */
public void updateSale(Stock stock){
    //在sql層面完成銷量+1 和 版本號 +1 并且根據(jù)商品id和版本號同時查詢更新的商品
    Integer updRows = stockMapper.updateSale(stock);   //更新信息
    if(updRows == 0){   //代表沒有拿到版本號
        throw new RuntimeException("搶購失敗,請重試!");
    }
}

也就是沒更新成功說明已經(jīng)秒殺完了, 相對悲觀鎖而言樂觀鎖保證了一定的效率,而不像悲觀鎖那樣會造成線程阻塞使用樂觀鎖需要使用版本號,在操作數(shù)據(jù)的時候要對版本號進(jìn)行更新

4.3 redis鎖setnx

但是上述代碼在高并發(fā),可能其他線程會釋放別人的鎖

4.4 使用Redision

https://github.com/redisson/redisson

5 分布式鎖的解決方案

實(shí)現(xiàn)分布式鎖的解決方案

6 采用緩存隊(duì)列防止超賣

高并發(fā)緩存隊(duì)列防止溢出解決方案

到此這篇關(guān)于Redis高并發(fā)場景下秒殺超賣解決的文章就介紹到這了,更多相關(guān)redis高并發(fā)秒殺超賣內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis高可用的三種實(shí)現(xiàn)方式

    Redis高可用的三種實(shí)現(xiàn)方式

    在實(shí)際生產(chǎn)環(huán)境中為保證Redis的服務(wù)連續(xù)性和可靠性,需要設(shè)計(jì)一個高可用架構(gòu),本文就來介紹一下Redis高可用的三種實(shí)現(xiàn)方式,主要包括主從復(fù)制模式,Redis Sentinel模式和Redis Cluster模式,感興趣的可以了解一下
    2023-12-12
  • 使用AOP+redis+lua做方法限流的實(shí)現(xiàn)

    使用AOP+redis+lua做方法限流的實(shí)現(xiàn)

    本文主要介紹了使用AOP+redis+lua做方法限流的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Redis IP地址的綁定的實(shí)現(xiàn)

    Redis IP地址的綁定的實(shí)現(xiàn)

    這篇文章主要介紹了Redis IP地址的綁定的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • redis命令行查看中文不亂碼的方法(十六進(jìn)制字符串處理)

    redis命令行查看中文不亂碼的方法(十六進(jìn)制字符串處理)

    這篇文章主要給大家介紹了關(guān)于redis命令行查看中文不亂碼的方法,其中詳細(xì)介紹了十六進(jìn)制字符串處理的相關(guān)資料,文中給出了詳細(xì)的示例代碼,供大家參考學(xué)習(xí),下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • Redis事務(wù)涉及的watch、multi等命令詳解

    Redis事務(wù)涉及的watch、multi等命令詳解

    這篇文章主要介紹了Redis事務(wù)涉及的watch、multi等命令,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2018-10-10
  • 淺談Redis常見延遲問題定位與分析

    淺談Redis常見延遲問題定位與分析

    大部分時候,redis延遲很低,但是在某些時刻,有些redis實(shí)例會出現(xiàn)很高的響應(yīng)延時,本文主要介紹了淺談Redis常見延遲問題定位與分析,具有一定的參考價值,感興趣的可以了解一下
    2022-06-06
  • Redis實(shí)現(xiàn)優(yōu)惠券限一單限制詳解

    Redis實(shí)現(xiàn)優(yōu)惠券限一單限制詳解

    這篇文章主要介紹了Redis解決優(yōu)惠券秒殺應(yīng)用案例,本文先講了搶購問題,指出其中會出現(xiàn)的多線程問題,提出解決方案采用悲觀鎖和樂觀鎖兩種方式進(jìn)行實(shí)現(xiàn),然后發(fā)現(xiàn)在搶購過程中容易出現(xiàn)一人多單現(xiàn)象,需要的朋友可以參考下
    2022-12-12
  • Redis實(shí)現(xiàn)庫存扣減的示例代碼

    Redis實(shí)現(xiàn)庫存扣減的示例代碼

    在日常開發(fā)中有很多地方都有類似扣減庫存的操作,本文主要介紹了Redis實(shí)現(xiàn)庫存扣減的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2023-07-07
  • 淺析Redis底層數(shù)據(jù)結(jié)構(gòu)Dict

    淺析Redis底層數(shù)據(jù)結(jié)構(gòu)Dict

    Redis是一個鍵值型的數(shù)據(jù)庫,我們可以根據(jù)鍵實(shí)現(xiàn)快速的增刪改查,而鍵與值的映射關(guān)系正是通過Dict來實(shí)現(xiàn)的,當(dāng)然?Dict?也是?Set?Hash?的實(shí)現(xiàn)方式,本文就詳細(xì)帶大家介紹一下Redis底層數(shù)據(jù)結(jié)構(gòu)?Dict,,需要的朋友可以參考下
    2023-05-05
  • redis 解決庫存并發(fā)問題實(shí)現(xiàn)數(shù)量控制

    redis 解決庫存并發(fā)問題實(shí)現(xiàn)數(shù)量控制

    本文主要介紹了redis 解決庫存并發(fā)問題實(shí)現(xiàn)數(shù)量控制,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04

最新評論