转载:

http://www.open-open.com/lib/view/open1430473257443.html

https://timyang.net/architecture/wechat-red-packet/

虽然春节已经过去一段时间,但不少微信群里面依旧乐此不疲的在玩发红包活动,用户自发的将最初的一个春节拜年的场景功能慢慢演化成一个长尾功能。

用户在微信中抢红包时分成抢包和拆包两个操作。抢包决定红包是否还有剩余金额,但如果行动不够迅速,在拆包阶段可能红包已经被其他用户抢走的情况。

红包的金额是在什么时候算? 据某架构群腾讯财付通专家反馈,红包的金额是拆的时候实时计算,而不是预先分配,实时计算基于内存,不需要额外存储空间,并且实时计算效率也很高。每次拆红包时,系统取0.01到剩余平均值*2之间作为红包的金额。

为了保证每次操作的原子性,拆包过程中使用了CAS,确保每次只有一个并发用户拆包成功。拆包CAS失败的用户可以由系统自动进行重试。但也有可能在重试过程中被别的用户抢得先机而空手而归,因此严格意义拆包的调用也未能保证用户先到先得。

基于上面的原因,当时在群中提到这种算法有些复杂,微信红包为了减少存储,每次进行了一个理解稍复杂的实时计算。对比大部分架构师想到的预分配金额 的做法,预先分配金额需要将金额保存在一个内存队列中,如果红包的份额较多,则需要较大的存储空间。而微信红包仅保存 count:balance 这样2个数字。count指还剩几个人可以抢,balance只还剩下的金额。

但是预分配金额也并不是非得需要额外存储。比如利用随机算法,在种子相同的情况下,随机数实际上返回的随机序列也是固定的。如以下Python代码,对于给定的seed 1024,每次执行返回的结果都是相同的。 
>>> import random 
>>> random.seed(1024) 
>>> random.randint(1,100) 
80 
>>> random.randint(1,100) 
49 
>>> random.randint(1,100) 
39 
>>> random.randint(1,100) 
83 
>>> random.randint(1,100) 
88

因此预分配金额也只需要额外存储一个种子,或利用一些红包id做加密变换做seed达到零存储。而在发放红包时候,无需进行CAS操作,而只需要对剩余红包count做一个DECR操作。当count

每个人分配的金额是:total * random(n) / random_total,不需要重复计算。 
random(1)..random(n)不需要保存,因为对于给定的seed,random(1)到random(n)返回是固定的。

以上算法评论与对比,与Tim所在雇主的红包算法无关,特此声明。

部分细节下面列表已做说明,未做详细阐述。

Reference: 
1、微信红包的架构设计简介 
2、网友周航老师基于聊天记录整理的微信红包架构图(点击查看大图) 
 
3、微信红包实现原理

对于上文中提到的架构群感兴趣的朋友可以关注Tim公众号“TimYang_net”后回复“arch”获取进群方式。

Similar Posts:

  • 微信架构的启示
  • 用Twitter的cursor方式进行Web数据分页
  • Feed消息队列架构分析
  • Google说,一个Datacenter就是一台计算机
  • 单元化与分布式架构的切分问题

原文链接: http://timyang.net/architecture/wechat-red-packet/

微信红包金额分配的算法相关推荐

  1. 红包拆分算法 php,关于PHP实现微信红包金额拆分的算法

    本篇文章主要介绍了PHP实现微信红包金额拆分试玩的算法示例,内容挺不错的,现在分享给大家,也给大家做个参考. 本文介绍了PHP实现微信红包金额拆分试玩的算法示例,分享给大家,有兴趣的可以看一下: ?p ...

  2. php数组10000分割1000_PHP切割整数工具类似微信红包金额分配的思路详解

    主要代码:NumberSlicing.php 思路:将数字按精度放大倍数,比如切割数字1,切割的份数是10,精度是0.01,则将1放大100 X 10倍,然后再来对加了1000倍权重后的值进行切割.切 ...

  3. php 微信红包瓜分,PHP实现微信红包金额拆分试玩的算法示例

    本文介绍了PHP实现微信红包金额拆分试玩的算法示例,分享给大家,有兴趣的可以看一下: // 新年红包金额拆分试玩 class CBonus { public $bonus;//红包 public $b ...

  4. php 随机钱数,PHP 仿微信红包金额随机

    博主寒冰最近闲来无事.就想研究一下微信红包的金额随机算法.早在微信红包刚出来的时候就研究过.始终不得要领.后来,通过查阅诸多资料.听说要实现"正态分布".这个理论的东西不想深挖.恰 ...

  5. php分割金额_PHP实现微信红包金额拆分及原理解析

    微信红包有个好玩的地方,比如可以将 10 元放入红包,设置红包数量为 10 个.然后系统会自动将这 10 元拆分,有的人可能领到了几块钱,而有的人就只领到了几分钱. 实现方法:function get ...

  6. 一个小玩意 PHP实现微信红包金额拆分试玩

    <meta charset="utf-8"> <?php // 新年红包金额拆分试玩class CBonus {public $bonus;//红包public ...

  7. php实现微信红包金额随机分配的函数

    <?php /*参数请自己校验$money 准备发送多少钱(分)$n 个数$rate 控制红包的系数 */ function makeRedPacket($money, $n, $rate = ...

  8. php 红包算法教程,php仿微信红包分配算法的实现方法

    php仿微信红包分配算法的实现方法 本文实例讲述了php仿微信红包分配算法的实现方法.分享给大家供大家参考,具体如下: /** * 红包分配:把一定金额随机分配给指定人数 * * @param int ...

  9. PHP实现微信随机红包算法和微信红包的架构设计简介

    微信红包的架构设计简介: 原文:https://www.zybuluo.com/yulin718/note/93148 @来源于QCon某高可用架构群整理,整理朱玉华. 背景:有某个朋友在朋友圈咨询微 ...

最新文章

  1. java中Pattern和Matcher的使用
  2. [react] 你有用过React.Fragment吗?说说它有什么用途?
  3. 网站服务器时间秒杀,Javascript实现商品秒杀倒计时(时间与服务器时间同步)...
  4. 数据结构拾遗(1) --红黑树的设计与实现(上)
  5. C语言--第2次作业
  6. Spark的分布式存储系统BlockManager全解析
  7. .net byte转java byte_CVE20200688的武器化与.net反序列化漏洞那些事
  8. javascript中this值的引用
  9. JavaScript上传图片方式
  10. 【发布】Arknights(明日方舟)拆包+桌面精灵
  11. 数字签名原理及其应用详解
  12. 1575万美元!2023科学突破奖揭晓,AlphaFold、量子计算等突破斩获殊荣
  13. iphone 通知声音_如何在iPhone上掌握通知
  14. 保姆级零基础 C 语言学习路线,万字总结!
  15. python 导入自己写的类
  16. SecureCRT 乱码问题
  17. Git概念:什么是分支
  18. 《现代永磁同步电机控制原理及MATLAB仿真》袁雷 - chp1
  19. Java JavaScript什么关系
  20. 量子力学是不完备的?

热门文章

  1. 马云:全面进军芯片领域!打响第一炮!中国科技当自强!!
  2. vue2和vue3响应式原理
  3. 现在的区块链现况技术如何?
  4. ps怎样新建渐变|自定义渐变
  5. 面对勒索软件,除了交赎金,还能怎么办?——我们有11个建议给你
  6. 苹果手机中计算机功能是什么,如何将苹果11手机中的内容和隐私访问限制功能关闭...
  7. Java 17全新特性,快到模糊
  8. 网易算法实习面经(2019.3)
  9. Unity3D学习笔记(一):Unity简介、游戏物体、组件和生命周期函数
  10. 把飞书融入日常学习流程:一个人的飞书也挺好