橡塑板厂家
免费服务热线

Free service

hotline

010-00000000
橡塑板厂家
热门搜索:
行业资讯
当前位置:首页 > 行业资讯

揭秘支持10亿个微信红包收发背后的惊人技术秘密

发布时间:2020-03-10 10:39:59 阅读: 来源:橡塑板厂家

A5交易A5任务 SEO诊断淘宝客 站长团购

摘要:2015年微信红包书,除夕摇一摇总次数110亿次,峰值1400万次/秒,8.1亿次每分钟,微信红包收发达10.1亿次!惊人数字再次让人们好奇,腾讯是怎样做技术支持的?

2014年双11的阿里淘宝超过500亿的巨大交易量,背后是阿里云极为特别强大的技术支持系统。2015年微信红包书,除夕摇一摇总次数110亿次,峰值1400万次/秒,8.1亿次每分钟,微信红包收发达10.1亿次!惊人数字再次让人们好奇,腾讯是怎样做技术支持的?下文作者节前采访到微信后台技术负责人,与大家分享红包背后的技术秘密。

4800倍的挑战

今年微信红包方式与去年用户与用户之间互发红包相比,摇红包的方式对业务量来说是一个极大的爆发,光是除夕10:30送出的1波红包就到达了1.2亿个,已是2014年除夕夜峰值的4800倍之巨(2014年峰值每分钟被拆开红包数量仅2.5W个)!

发10亿红包,难在哪里?

微信团队总结下来有三大难点:

快如何保证用户快速摇到红包?

准如何保证摇到的红包能成功拆开?

稳如何保证拆开的红包能分享出去?

大量用户在同一时间摇红包,瞬间产生每秒千万级的要求,这个量级的要求如果不加以疏导处理直接到达后台,一定会致使后端服务过载乃至崩溃。上文中除夕当天后台监控数据曲线便能说明一切在前台重重的分流减压下,后台服务器负载依然瞬间飙升十倍以上。

3大应对策略齐上阵

对以上三个难点,微信后台开发团队主要通过3大应对策略应对:有损服务,柔性可用,大系统小做。

有损服务-寻求高可用和快速响应

什么是有损服务?有损服务是通过精心拆分产品流程,选择性牺牲一部分数据一致性和完整性从而保证核心功能绝大多数运行。这是腾讯在PC时期积累下来的一种特点运营策略在资源一定的条件下,互联网条件千变万化的场景中,量力而为,满足用户的核心需求。

微信红包的核心点是摇,拆,分享红包,全部系统设计时必须尽最大可能保证这三个步骤一气呵成,任何关联系统出现异常的时候马上进行系统降级,避免引发系统雪崩。

系统降级可以分为两个方面,1是把核心功能进行分拆和简化,通过辅助轻量化的服务实现,确保最短关键路径的可行,比方说在接入层置入摇红包逻辑,将每秒千万级要求转化为每秒万级的红包要求,再传到红包服务的后端逻辑,下降雪崩的可能性。

同时后端采取异步分拆,接收到用户要求时仅进行合法性验证,验证完成后直接告知成功,后续业务逻辑进入异步队列进行处理,减少了用户的等待时间,也极大下降了峰值雪崩的几率。

另外一方面是采取过载保护措施。微信红包的过载保护在客户端已提早预埋了策略,在连接失败或超时情况下会有相应提示,减少用户重复要求次数。接入层面也会进行自我保护,针对频繁发出要求的客户端限制响应速度,并对系统负载划分出若干等级,到达不同阈值时引导客户端使用不同限速速率;在异常情况出现时,采取减少红包数,异步限流下降拆/分享红包的速率等措施减轻服务器端压力;与此同时,微信红包还有全程压测流程,对全部业务链接进行自动提早评估,避免过载。

这画面你可能没见过,它其实早已在手机待命

在有损服务思想的重重保护下,第一波的摇红包体验活动中,微信红包几近满分通过考验,其中过载保护的作用相当明显,在客户端、接入层层减压、过滤,终究仅把十万级压力传递到后台。

柔性可用-细化场景掌控核心需求。

柔性可用是在有损服务价值观支持下的方法,重点在于实际上会结合用户使用场景,根据资源消耗,调剂产品策略,设计几个级别不同的用户体验场景,保证尽量成功返回关键数据,并正常接受要求,绝不轻易倒下。

柔性服务更具有产品的思惟性质,意义在于深入理解产品每个场景的核心价值,掌控用户在每个场景中的核心需求,设计不同层次的满足核心诉求的办法,对柔性服务在微信红包中的实践,红包团队也有相应的措施,主要可以分为几大类。

1、系统容灾:面对大规模的要求量,系统容灾必不可少,容灾一般可分为逻辑层容灾和数据层容灾,这次微信后台开发团队在容灾布置中采取30%切换的逻辑层方案,即核心服务都能做到最多1/3服务器出问题的情况下自动容灾切换以保证服务质量,提高预警级别换取系统的可用性。

2、资源隔离:顾名思义就是把资源进行隔离减少服务支路间的影响,从逻辑入手,在资源逻辑中,当A服务同时分派任务给BC服务时,设定单个最大分配上限值,避免任意一个支路出问题影响全部服务链条,这样即便部份服务出现问题也不会影响到全部服务的崩塌。

3、快速谢绝:当服务过载时尽早谢绝要求,由服务调用方换机重试避免单一服务器重试过载,快速谢绝和有损服务中的尽早谢绝是一个概念的方法,从进程的源头将问题解决,本钱越低,影响越小,前端保护后端的方式来解决问题。

4、支付分组:从支付环节入手,将所有红包分为50个组,放在50个单独的set上互不影响,单组set出问题最多只影响1/50用户,保证多数人服务不受干扰。分组set化也是柔性可用的一个重要技术手段,这1思惟非常类似于现实生活中的集装箱思惟通过标准化,规模化的箱体设计,应对复杂多样的货物,使每一个流通环节既独立又不失灵活。

5、流量预加载:从客户端入手,将语音图片等极消耗流量的资源提早让客户端自动下载预置好,提早将流量洪峰疏导,并在活动当天CDN将准备数百G带宽应对,这块也与过载保护中的快慢分离是相通的,将耗流量的服务提早加载避免高峰期间的冲突。

大系统小做-保证进程的功能单一

大系统小做应当来讲,是一种意识,他的核心思想是将功能复杂较大的系统,化大为小,减少模块耦合,下降关联性,用多个独立的模块来实现整体系统的功能,大系统小做采取的是化繁为简,分而治之,便于开发和迅速实现。

微信红包如此庞大的后台系统,模块也相当之多,而这次的模块微信开发后台团队采取了系统高度模块化的方式,分成一个个高度自制的小系统,构成高内聚低耦合的格局,每一个模块之间不会过分依赖对方,这样的好处是不会由于任何一个模块而影响全部服务,避免牵1发动全身的风险,实现真正的灰度服务。

海量服务能力决定成败

从2014的滴滴打车,到2015的微信红包,腾讯用一个个案例,去证明本身在海量服务方面的实力。事实上,真正支持起微信红包顺畅运营的幕后英雄,正是腾讯内部一个叫做海量之道2.0的技术体系。

有损服务,柔性服务,大系统小做三大手段也是脱胎于此体系中。移动互联网大战硝烟味愈浓,BAT都在为争取支付入口使出浑身解数,在业务从起步到小跑再到腾飞的进程中,巨头背后的海量服务能力将对其终究成败有着来越发深远的影响。

成都到鄂尔多斯货运公司

成都到安庆物流价格

成都到昆明货运公司

成都到阳江物流