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

Redis分布式緩存:微信搶紅包解決方案

 更新時(shí)間:2021年12月10日 15:11:47   作者:小伙子vae  
微信搶紅包已經(jīng)在我們生活中很常見的場景了,特別是年底公司開年會(huì)和春節(jié)2個(gè)時(shí)間段。本文主要介紹了通過Redis實(shí)現(xiàn)微信搶紅包功能,感興趣的小伙伴可以了解一下

一、場景分析

微信搶紅包已經(jīng)在我們生活中很常見的場景了,特別是年底公司開年會(huì)和春節(jié)2個(gè)時(shí)間段,長輩領(lǐng)導(dǎo)都發(fā)紅包,手都點(diǎn)抽筋了,也沒搶到多少。

在這段時(shí)間里,對于單個(gè)群里的單個(gè)紅包,qps也是上千的,對于整個(gè)微信紅包系統(tǒng),高峰的并發(fā)量是上億的。

高峰的搶紅包有3大特點(diǎn):

  1. 包紅包的人多:也就是創(chuàng)建紅包的任務(wù)比較多,即紅包系統(tǒng)是以單個(gè)紅包的任務(wù)來區(qū)分,特點(diǎn)就是在高峰期紅包任務(wù)多。
  2. 搶紅包的人更多:當(dāng)你發(fā)紅包出去后,是幾十甚至幾百人來搶你的紅包,即單紅包的請求并發(fā)量大。
  3. 低延遲:當(dāng)你發(fā)現(xiàn)紅包時(shí),要越快搶到越開心,所以要求搶紅包的響應(yīng)速度要快,一般1秒響應(yīng)。

二、技術(shù)方案

1.包紅包

先把金額拆解為小金額的紅包,例如 總金額1000元,發(fā)10個(gè),用戶在點(diǎn)保存的時(shí)候,就自動(dòng)拆解為10個(gè)隨機(jī)小紅包。

這里的存儲(chǔ)就是個(gè)難題,多個(gè)金額(例如10個(gè)小金額的紅包)如何存儲(chǔ)?

2.搶紅包

高并發(fā)的搶紅包時(shí)核心的關(guān)鍵技術(shù),就是控制各個(gè)小紅包的操作的原子性。

例如 10個(gè)紅包在100人的群里被搶,10個(gè)紅包被搶走一個(gè)的同時(shí)要紅包的庫存減1,即剩下19個(gè)。在整個(gè)過程中搶走一個(gè)和紅包庫存減1個(gè)是一個(gè)原子操作。

list的pop操作彈出一個(gè)元素的同時(shí)會(huì)自動(dòng)從隊(duì)列里面剔除該元素,它是一個(gè)原子性操作。

三、案例實(shí)戰(zhàn)

包紅包

    /**
     * 包紅包的接口
     */
    @GetMapping(value = "/set")
    public long setRedpacket(int total, int count) {
        //拆解紅包
        Integer[] packet= this.splitRedPacket(total,count);
        //為紅包生成全局唯一id
        long n=this.incrementId();
        //采用list存儲(chǔ)紅包
        String key=RED_PACKET_KEY+n;
        this.redisTemplate.opsForList().leftPushAll(key,packet);
        //設(shè)置3天過期
        this.redisTemplate.expire(key,3, TimeUnit.DAYS);
        log.info("拆解紅包{}={}",key,packet);
        return n;
    }

拆解紅包

/**
 * 拆解紅包
 * 1.紅包金額要被全部拆解完
 * 2.紅包金額不能差太離譜
 * total 紅包金額
 * count 紅包數(shù)量
 */
public  Integer[] splitRedPacket(int total, int count) {
    int use = 0;
    Integer[] array = new Integer[count];
    Random random = new Random();
    for (int i = 0; i < count; i++) {
        if (i == count - 1)
            array[i] = total - use;
        else {
            // 紅包隨機(jī)金額浮動(dòng)系數(shù)
            int avg = (total - use) * 2 / (count - i);
            array[i] = 1 + random.nextInt(avg - 1);
        }
        use = use + array[i];
    }
    return array;
}

搶紅包?

    
    /**
     * 搶紅包接口
     */
    @GetMapping(value = "/rob")
    public int rob(long redid,long userid) {
        //第一步:驗(yàn)證該用戶是否搶過
        Object packet=this.redisTemplate.opsForHash().get(RED_PACKET_CONSUME_KEY+redid,String.valueOf(userid));
        if(packet==null){
            //第二步:從list隊(duì)列,彈出一個(gè)紅包
            Object obj=this.redisTemplate.opsForList().leftPop(RED_PACKET_KEY+redid);
            if(obj!=null){
                //第三步:搶到紅包存起來
                this.redisTemplate.opsForHash().put(RED_PACKET_CONSUME_KEY+redid,String.valueOf(userid),obj);
                log.info("用戶={}搶到{}",userid,obj);
                //TODO 異步把數(shù)據(jù)落地到數(shù)據(jù)庫上
                
                return (Integer) obj;
            }
            //-1 代表搶完
            return -1;
        }
        //-2 代表已搶
        return -2;
    }
 

到此這篇關(guān)于Redis分布式緩存:微信搶紅包解決方案的文章就介紹到這了,更多相關(guān)Redis微信搶紅包內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis之sql緩存的具體使用

    Redis之sql緩存的具體使用

    本文主要介紹了Redis之sql緩存的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Redis Scan命令的基本使用方法

    Redis Scan命令的基本使用方法

    這篇文章主要給大家介紹了關(guān)于Redis中Scan命令的基本使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Go語言操作RediSearch進(jìn)行搜索方法示例詳解

    Go語言操作RediSearch進(jìn)行搜索方法示例詳解

    這篇文章主要為大家介紹了Go語言操作RediSearch進(jìn)行搜索方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 單線程Redis快的4 個(gè)原因總結(jié)

    單線程Redis快的4 個(gè)原因總結(jié)

    作為內(nèi)存中數(shù)據(jù)存儲(chǔ),Redis 以其速度和性能著稱,通常被用作大多數(shù)后端服務(wù)的緩存解決方案,但是,在內(nèi)部,Redis 采用單線程架構(gòu),為什么單線程設(shè)計(jì)依然會(huì)有這么高的性能,在本文中,讓我們深入探討為什么 Redis 才有單線程架構(gòu)
    2023-07-07
  • redis批量刪除指定前綴key四種方法(收藏)

    redis批量刪除指定前綴key四種方法(收藏)

    這篇文章主要介紹了redis批量刪除指定前綴key四種方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-03-03
  • Redis概述及l(fā)inux安裝redis的詳細(xì)教程

    Redis概述及l(fā)inux安裝redis的詳細(xì)教程

    這篇文章主要介紹了Redis概述及l(fā)inux安裝redis的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Redis分布式鎖解決秒殺超賣問題

    Redis分布式鎖解決秒殺超賣問題

    本文主要介紹了Redis分布式鎖解決秒殺超賣問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 在CentOS 7環(huán)境下安裝Redis數(shù)據(jù)庫詳解

    在CentOS 7環(huán)境下安裝Redis數(shù)據(jù)庫詳解

    Redis是一個(gè)開源的、基于BSD許可證的,基于內(nèi)存的、鍵值存儲(chǔ)NoSQL數(shù)據(jù)本篇文章主要介紹了在CentOS 7環(huán)境下安裝Redis數(shù)據(jù)庫詳解,有興趣的可以了解一下。
    2016-11-11
  • redis中scan命令的基本實(shí)現(xiàn)方法

    redis中scan命令的基本實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于redis中scan命令的基本實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • windows下使用redis requirepass認(rèn)證不起作用的解決方法

    windows下使用redis requirepass認(rèn)證不起作用的解決方法

    今天小編就為大家分享一篇windows下使用redis requirepass認(rèn)證不起作用的解決方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05

最新評論