红包雨架构的设计汇总

一 微服务总体架构

1.1 微服务总体架构

1.2 红包雨的流程

1.3 发红包的内容

1.3.1 概述流程

1.发红包-》抢红包。

1.所有人签到的金额之和等于红包总金额。2.每个人至少抢到一分钱;3.保证所有人抢到金额的几率相等。

1.3.2 拆分红包通用流程算法

其中拆红包最为关键,设计的算法是:二倍均值算法。

二倍均值算法:剩余的余额M,剩余的人数N,每次抢到红包数=随机区间(0,(M/N)*2)

这个公式:保证每次随机金额是均值相等的,不会因为抢红包的先后顺序造成不公平。这句话不理解耶???

复制代码
package com.ljf.redis.redpackage;

import java.util.Arrays;
import java.util.Random;

/**
 * @ClassName: TwoAvgSuanFa
 * @Description: TODO
 * @Author: admin
 * @Date: 2023/07/21 10:20:24 
 * @Version: V1.0
 **/
public class TwoAvgSuanFa {
    public static void main(String[] args) {
       Integer[] integers= sendAvgPackage(100,5);
       System.out.println(""+ Arrays.toString(integers));
    }
    public static Integer[] sendAvgPackage(int totalMoney,int redPackagNum){
        Integer[] rpNumberArrays=new Integer[redPackagNum];
        int useMoney=0;
        for(int i=0;i<redPackagNum;i++){
            if(i==redPackagNum-1){
                rpNumberArrays[i]=totalMoney-useMoney;
            }
            else {
                int avgMoney=((totalMoney-useMoney)/(redPackagNum-i))*2;
                System.out.println("avgMoney:"+avgMoney);
                rpNumberArrays[i]=1+new Random().nextInt(avgMoney-1);
            }
            useMoney=useMoney+rpNumberArrays[i];
        }
        return rpNumberArrays;
    }
}

结果:

1.3.3 红包雨的架构流程

1.发红包

1.按照金额M,红包人数N,使用二倍均值法,将M分成N个子红包。使用redis的list数据结构进行存储。

逻辑

2.抢红包

1.从redis的红包池list中使用lpop命令进行取出数据消费,且和用户进行绑定,在redis中使用hash结构记录抢红包的记录。

2.每次抢红包前从redis的 hash结构中查询是否已经存在抢红包记录,无则抢,有则不让再抢。

1.3.4 红包雨的v2版本

待完善....

相关推荐
爱艺江河15 分钟前
HarmonyOS智慧风控:基于分布式架构的安全与创新实践
分布式·架构·harmonyos
juniperhan16 分钟前
Flink 系列第18篇:Flink 动态表、连续查询与 Changelog 机制
java·大数据·数据仓库·分布式·flink
juniperhan22 分钟前
Flink 系列第19篇:深入理解 Flink SQL 的时间语义与时区处理:从原理到实战
java·大数据·数据仓库·分布式·sql·flink
珠海西格电力26 分钟前
零碳园区管理系统“云-边-端”架构协同的核心价值
大数据·人工智能·分布式·微服务·架构·能源
fuquxiaoguang40 分钟前
金蝶天燕AMDC:当企业级缓存遇见Redis 8.2,国产中间件的“性能+易用”双飞跃
redis·缓存·中间件
GIS数据转换器42 分钟前
延凡分布式光伏集中监控平台
人工智能·分布式·数据挖掘·数据分析·无人机·智慧城市
早睡早起早日毕业43 分钟前
大数据管理与应用系列丛书《大数据平台架构》之第2章 分布式理论基础:大数据系统的架构基石
大数据·hadoop·分布式·架构
卷毛的技术笔记1 小时前
告别“盲猜式”排障:分布式链路追踪方案选型与Spring Boot 3实战
java·spring boot·分布式·后端·spring·面试·系统架构
y = xⁿ1 小时前
Redis:分布式锁,Redisson以及看门狗机制解析
数据库·redis·分布式
无忧智库1 小时前
计量先行:虚拟电厂分布式资源接入的底层逻辑与工程实践深度解析(PPT)
分布式