招行面试:如何让系统抗住双十一 预约抢购活动?10Wqps级抢购, 做过吗?

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: 本文由40岁老架构师尼恩撰写,针对一线互联网企业如得物、阿里、滴滴等的面试题进行深度解析。文章聚焦于如何设计系统以应对大促活动中的预约抢购场景,涵盖从预告到支付的完整流程。尼恩通过系统化、体系化的梳理,帮助读者提升技术实力,轻松应对高并发挑战,并提供了详细的架构设计和解决方案。文中还分享了《尼恩Java面试宝典》等资源,助力求职者在面试中脱颖而出,实现“offer直提”。更多内容及PDF资料,请关注公众号【技术自由圈】获取。

本文原文链接

尼恩说在前面

在40岁老架构师 尼恩的读者交流群(50+)中,最近有小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、希音、百度、网易、美团的面试资格,

最近有小伙伴面试招商银行,遇到下面的绝命 12题,狠狠被拷打了, 彻底懵了。 项目场景题太难了,不好好准备,真的答不出!

image.png

所以,尼恩给大家做一下系统化、体系化的梳理,使得大家内力猛增,可以充分展示一下大家雄厚的 “技术肌肉”,让面试官爱到 “不能自已、口水直流”,然后实现”offer直提”。

当然,这些面试题 以及参考答案,也会收入咱们的 《尼恩Java面试宝典PDF》V171版本,供后面的小伙伴参考,提升大家的 3高 架构、设计、开发水平。

最新《尼恩 架构笔记》《尼恩高并发三部曲》《尼恩Java面试宝典》的PDF,请关注本公众号【技术自由圈】获取,回复:领电子书

绝命12题, 尼恩将给出全部的深度答案:

1.如何让系统抗住大促的预约抢购活动?

16大绝招,完成10Wqps秒杀架构(3万字架构长文)

2.如何从零搭建10万级QPS大流量、高并发优惠券系统?

尼恩梳理的 参考答案 , 点击查看

3.百万级别数据的 Excel 如何快速导入到数据?

尼恩梳理的 参考答案 , 点击查看

4.如何设计一个支持万亿GB网盘实现秒传与限速的系统?

尼恩梳理的 参考答案 , 点击查看

5.如何根据应用场景选择合适的消息中间件?

即将发布。

6.如何提升 RocketMQ 顺序消费性能?

即将发布。

7.使用分布式调度框架该考虑哪些问题?

即将发布。

9.如何让系统抗住大促的预约抢购活动?

本文。

10.问 : 如何解决高并发下的库存抢购超卖少买?

即将发布。

11.为什么高并发下数据写入不推荐关系数据?

即将发布。

12.如果让你设计一个分布式链路跟踪系统?

即将发布。

本文目录

一:预约抢购” 的三个阶段 :

在大促活动期间,“预约抢购” 是各大 电商平台 的主要促销手段, 比如 2019 年的 “1499 元抢购飞天茅台”活动,

那么,如何才能让系统抗住大促的预约抢购活动?

或者,如何才能 让系统抗住双十一的预约抢购活动?

尼恩给大家系统化、体系化的梳理一下。

我们先把需求梳理一下,总的来说,实现一个抢购系统大概可以分为3个阶段。

整体功能 分为 “抢购预告”、“抢购下单” 和 “订单支付” 三个阶段、三个功能,代表用户在双十一大促抢购活动中的不同阶段。

image.png

抢购预告阶段

目的在于吸引用户关注、激发用户参与抢购的兴趣,让用户提前做好准备。

主要是提前向用户展示即将开展抢购活动的相关信息,像参与抢购的商品品类、各商品的大致优惠幅度、具体的抢购开始时间等内容。

商品抢购阶段

对于抢购详情页面,临近抢购倒计时,页面查询请求剧增。为应对这一情况,采取页面静态化和服务端限流措施。页面静态化使页面能快速加载,减少动态请求压力;服务端限流则控制单位时间内请求数量,防止流量过大导致系统崩溃。

对于抢购下单,由于瞬时下单操作对DB带来巨大压力,需要通过 MQ(消息队列)将同步转异步,实现流量削峰。这使得请求排队等待,有序且有限地进入后端服务。同时,要解决消息队列的丢失、重复和积压问题。扣减库存时,引入锁机制,防止扣减存储超售,和保障操作的幂等性。 通过本地消息表事务,保障秒杀订单服务/ 库存服务/积分服务/优惠券服务的最终一致性。

订单支付阶段

用户支付完成后,通过 MQ 通知方式实现系统间解耦和异步通信。确保消息可靠性,也可通过 RPC(远程过程调用)同步调用方式。掌握 RPC 和 MQ 的相关知识点,保证支付完成后系统的稳定运行。

二: 预告阶段的架构设计

抢购的预告阶段,目的在于吸引用户关注、激发用户参与抢购的兴趣,让用户提前做好准备。

抢购的预告阶段,主要是提前向用户展示即将开展抢购活动的相关信息,像参与抢购的商品品类、各商品的大致优惠幅度、具体的抢购开始时间等内容。

抢购的预告阶段,采用分层架构来应对高并发的抢购预告请求。

抢购预告 阶段 是4层,主要分为:

  • 接入层
  • 业务逻辑层
  • 缓存层
  • 数据存储层

抢购预告阶段 的 接入层、业务逻辑层、数据存储层以及缓存层,各层协同工作确保系统能够高效、稳定地处理大量并发请求并准确展示抢购预告信息。

image.png

(1)抢购预告接入层

负载均衡

使用专业的负载均衡设备(如硬件负载均衡器 F5 或者软件负载均衡器 Nginx 等),按照一定的算法(如轮询、IP 哈希等)将大量用户的请求均匀分发到后端的多个业务服务器上,避免单点服务器出现过载的情况,有效提升系统整体的并发处理能力。

请求过滤与验证

对传入的请求进行合法性检查,比如验证请求的来源 IP 是否在允许范围内、请求格式是否符合规范等,拦截非法请求,减轻后续业务逻辑层的处理压力。

(2)抢购预告业务逻辑层

信息整合与组装

从缓存层获取商品相关的基础信息(如商品品类、大致优惠幅度等)以及从数据库获取最新的动态信息(如临时调整的优惠规则等),将这些信息进行整合组装,形成完整的抢购预告内容。

消息队列应用

如果存在需要实时推送的信息更新(如优惠力度变化等情况),借助消息队列(如 RabbitMQ、Kafka 等)来实现异步通知,业务逻辑层将更新消息发送到消息队列中,由专门的消费者去处理更新并推送到前端展示,确保数据实时性的同时不会阻塞主要的请求处理流程。

(3)抢购预告缓存层

静态资源缓存

采用动静分离策略,将商品图片、固定的文案描述等静态资源缓存到 CDN(内容分发网络)中。

CDN 在全球各地有众多节点,当不同地区用户发起请求时,能从距离最近的节点快速获取这些静态资源,大大缩短资源获取时间,减轻后端服务器压力。

image.png

动态数据缓存(部分)

在抢购预告中,对于一些相对变动不那么频繁的商品动态数据(如短期内不会改变的商品品类列表等),可以缓存到内存数据库(如 Redis)中。

通过 Cache Aside 模式进行redis 和db的访问 ,在业务逻辑层查询时先从 Redis 中获取 动态数据,若不存在, 再去数据库查询。

如何保障 数据一致性呢? 通过设置合理的缓存过期时间和更新机制,保证数据的时效性和准确性。

image.png

以 抢购预告的类目列表为例,流程如下:

image.png

三:预告阶段的架构难点:

难点1:页面优化与缓存策略:

面对大量用户同时访问预告页面的情况,需对页面进行性能优化。

采用动静分离的方式,将商品图片、固定的文案描述等静态资源通过 CDN(内容分发网络)进行缓存,这样能让不同地区的用户快速获取到这些资源,减轻后端服务器的压力,保障页面能在高并发访问下快速加载呈现。

难点2:数据实时更新与一致性保障:

对于商品信息、优惠规则等动态数据,要确保其能实时准确地展示给用户。

后端数据库的数据变更(比如临时调整优惠力度等)需要及时同步到前端,可通过消息队列等机制来实现数据的异步更新推送,避免出现用户看到的预告内容与实际抢购情况不符的问题。

难点3:流量监控与预警:

搭建完善的流量监控系统,实时监测访问该阶段页面的流量情况,设定合理的阈值,

当流量接近或超过系统承载能力时能够及时发出预警,以便运维团队提前做好应对准备,比如动态增加服务器资源等。

四:抢购下单阶段的架构设计

下单业务特点与目标:

这是整个抢购活动最为关键且高并发压力最大的阶段,众多用户会在同一时间点尝试下单 ,这里存在巨大的顺时流量、突发流量。

顺时流量、突发流量 场景,在涉及高并发难题的同时,还要做到到对库存的准确扣减、订单生成的合法合规的等重要业务操作。

下单阶段 需要确保整个下单流程快速,且不出差错,以提升用户的抢购体验和保障商家利益。

抢购下单阶段的4层架构

抢购的下单阶段,同样 采用分层架构来应对高并发 请求进行处理。

抢购下单阶段也是4层,主要分为:

  • 接入层

  • 业务逻辑层

  • MQ层

  • 数据存储层

其中业务逻辑层解耦为:

  • 库存预扣服务
  • 订单生成服务

各层协同工作确保系统能够高效、稳定地处理大量并发请求并准确完成下单操作。

image.png

(1) 库存预扣服务 架构设计:

采用分布式缓存(如 Redis 等)来预先存储商品库存,在用户下单时先从缓存层进行库存预扣减操作,这个环节,利用缓存的高性能读写特性加快响应速度。

同时,要结合数据库的持久化存储,通过异步MQ层 将缓存中的库存变动同步到数据库中,确保数据最终一致性。

image.png

(2) 订单生成服务 的架构设计:

设计高效的订单生成逻辑,快速生成唯一且符合规范的订单号,将商品信息、订单信息等关键数据准确无误地写入数据库中的订单表。

订单生成过程中,运用合适的锁机制(如分布式锁、乐观锁等),有效避免超卖情况发生,保证同一商品在同一时刻只有一个有效的库存扣减操作在执行。

可以借助数据库连接池技术来管理数据库连接,提高订单写入的效率,减少因频繁创建和销毁数据库连接导致的性能损耗。

image.png

(3) 高并发抢购下单的核心策略:

第一: 限流设计

设置合理的限流策略,例如基于令牌桶算法、漏桶算法等方式,限制单位时间内进入下单流程的请求数量,对超出限制的请求可以进行排队等待或者友好提示用户稍后再试。

第二:降级设计

同时,制定降级方案,当一些非核心服务(如商品关联推荐服务等)出现故障或者性能瓶颈时,能够暂时关闭这些服务,优先保障下单这一核心功能的稳定运行,避免整个系统因局部问题而崩溃。

image.png

五:订单支付阶段

业务特点与目标

用户完成下单后进入支付环节,支付环节 需要很多安全保障:

  • 第一,需要保障支付过程的安全、稳定以及与各支付渠道(如支付宝、微信支付等)的顺畅对接。
  • 第二,需要准确更新订单的支付状态,确保整个交易流程的完整性,让用户放心完成支付。

订单支付阶段的大致流程:

  • 用户完成下单后进入支付环节,调用 支付平台 的接口,发起支付流程

  • 在用户支付订单完成之后,一般会由支付平台回调系统接口,更新订单状态。

  • 在支付回调成功之后,抢购系统还会通过异步通知的方式,实现订单更新之外的非核心业务处理,比如积分累计、短信通知等,此阶段可以基于 MQ 实现业务的异步操作。

image.png

5.1 订单支付后设计

不过针对服务的异常(如宕机),会存在 MQ消息数据丢失的可能,

比如当支付回调系统后,修改订单状态成功了,但是, 在异步通知积分系统, MQ消息数据丢失 ,其他的业务就没有 处理了,出现了数据不一致性问题。

image.png

5.2 订单支付后操作(异常)

所以你还要考虑 可靠消息投递机制:先做消息的本地存储,再通过异步重试机制,来实现消息的补偿。

比如当支付平台回调订单系统,然后在更新状态的同时,插入一个消息,之后再返回第三方支付操作成功的结果。

最后,通过数据库中的这条消息,再通过XXL-JOB 订单核对方式机制,完成后续的工作。

另外,也可以采用消息的0丢失机制,保障消息不丢失。消息的0丢失机制, 具体请参见下面的文章:

滴滴面试:Rocketmq消息0丢失,如何实现?

5.3:异常处理与补偿机制:

针对支付过程中可能出现的各种异常情况,比如网络波动导致支付结果未及时返回、用户主动取消支付等,需要建立完善的异常处理和补偿机制。

例如,设置xxl-job 定时任务定期查询处于未确定支付状态的订单情况,提供给用户相应的操作入口(如重新支付、取消订单等),保障用户能顺利完成支付或者妥善处理异常订单,维护好用户体验和整个交易流程的顺畅性。

5.4 支付阶段技术设计难点

难点1:支付接口集成与安全保障
与各类支付平台进行严谨的接口对接,按照支付平台要求做好接口参数的传递、加密、签名等安全措施,防止支付信息在传输过程中被篡改。

需要对支付接口进行充分的测试,确保其在高并发环境下的稳定性和可靠性,能够及时准确地向支付平台发起支付请求并接收支付结果回调。

难点2:订单状态更新与事务管理
依据支付结果来精准更新订单的状态,如支付成功后将订单标记为 “已支付”,支付失败则相应标记为 “支付失败” 等。

这一过程要保证在高并发情况下状态更新的一致性,可借助数据库事务机制或者可靠的消息队列来实现,需确保支付成功后,与之关联的库存、财务等相关数据也能同步正确更新,避免出现数据不一致导致的后续业务问题。

说在最后:有问题找老架构取经‍

回到开始的时候的面试题:招商银行的Java后端面试真题

被狠狠拷打了,问的人都懵了。 项目场景题太难了,不好好准备,真的答不出!

image.png

按照尼恩的参考答案回答,一定会 吊打面试官,让面试官爱到 “不能自已、口水直流”,然后实现”offer直提”。

在面试之前,建议大家系统化的刷一波 5000页《尼恩Java面试宝典PDF》,里边有大量的大厂真题、面试难题、架构难题。

很多小伙伴刷完后, 吊打面试官, 大厂横着走。

在刷题过程中,如果有啥问题,大家可以来 找 40岁老架构师尼恩交流。

另外,如果没有面试机会,可以找尼恩来改简历、做帮扶。前段时间,刚刚指导 一个2年经验小伙,拿到 年薪60W的 天价年薪 ,3大 offer, 实现了一本 吊打 985、211

狠狠卷,实现 “offer自由” 很容易的, 前段时间一个武汉的跟着尼恩卷了2年的小伙伴, 在极度严寒/痛苦被裁的环境下, offer拿到手软, 实现真正的 “offer自由” 。

尼恩技术圣经系列PDF

……完整版尼恩技术圣经PDF集群,请找尼恩领取

《尼恩 架构笔记》《尼恩高并发三部曲》《尼恩Java面试宝典》PDF,请到下面公号【技术自由圈】取↓↓↓

相关文章
|
9天前
|
存储 API 文件存储
招行面试:万亿GB网盘, 从0到1设计,如何实现?
本文由40岁老架构师尼恩撰写,针对一线互联网企业如得物、阿里、滴滴等的面试场景,特别是招商银行Java后端面试中的绝命12题,进行了深度解析。尼恩通过系统化、体系化的梳理,帮助读者提升技术肌肉,让面试官爱到“不能自已”。文章详细分析了如何设计一个支持万亿GB网盘实现秒传与限速的系统,涵盖了高并发处理、秒传实现、限速设计等核心技术挑战,并提供了完整的架构设计和代码示例。此外,还介绍了《尼恩Java面试宝典PDF》V171版本,帮助读者更好地准备面试。关注公众号【技术自由圈】,回复“领电子书”,获取更多资源。
|
2天前
|
NoSQL 关系型数据库 MySQL
招行面试:高并发写,为什么不推荐关系数据?
资深架构师尼恩针对高并发场景下为何不推荐使用关系数据库进行数据写入进行了深入剖析。文章详细解释了关系数据库(如MySQL)在高并发写入时的性能瓶颈,包括存储机制和事务特性带来的开销,并对比了NoSQL数据库的优势。通过具体案例和理论分析,尼恩为读者提供了系统化的解答,帮助面试者更好地应对类似问题,提升技术实力。此外,尼恩还分享了多个高并发系统的解决方案及优化技巧,助力开发者在面试中脱颖而出。 文章链接:[原文链接](https://mp.weixin.qq.com/s/PKsa-7eZqXDg3tpgJKCAAw) 更多技术资料和面试宝典可关注【技术自由圈】获取。
|
11天前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
3月前
|
缓存 算法 架构师
京东面试:如何设计600Wqps高并发ID?如何解决时钟回拨问题?
资深架构师尼恩在其读者交流群中分享了关于分布式ID系统的设计与实现,特别是针对高并发场景下的解决方案。他强调了分布式ID系统在高并发核心组件中的重要性,并详细介绍了百度的UidGenerator,这是一个基于Snowflake算法改进的Java实现,旨在解决分布式系统中的唯一ID生成问题。UidGenerator通过自定义workerId位数和初始化策略,支持虚拟化环境下的实例自动重启和漂移,其单机QPS可达600万。此外尼恩的技术分享不仅有助于提升面试表现,还能帮助开发者在实际项目中应对高并发挑战。
京东面试:如何设计600Wqps高并发ID?如何解决时钟回拨问题?
|
3月前
|
C语言
经典面试题:嵌入式系统中经常要用到无限循环,怎么样用C编写死循环呢
在嵌入式系统开发中,无限循环常用于持续运行特定任务或监听事件。使用C语言实现死循环很简单,可以通过`while(1)`或`for(;;)`的结构来编写。例如:`while (1) { /* 循环体代码 */ }`,这种写法明确简洁,适用于需要持续执行的任务或等待中断的场景。
|
3月前
|
存储 消息中间件 缓存
系统设计面试参考-设计Spotify系统
【10月更文挑战第4天】支持用户将自己喜欢的音乐、专辑、播放列表等分享到社交媒体平台,如 Facebook、Twitter、Instagram 等。分享内容可以包括音乐链接、封面图片、简介等信息,吸引更多的用户来使用 Spotify 系统。同时,系统可以跟踪分享的效果,如点击量、转化率等,以便评估社交分享对系统推广的贡献。
|
6月前
|
设计模式 存储 安全
Java面试题:设计一个线程安全的单例类并解释其内存占用情况?使用Java多线程工具类实现一个高效的线程池,并解释其背后的原理。结合观察者模式与Java并发框架,设计一个可扩展的事件处理系统
Java面试题:设计一个线程安全的单例类并解释其内存占用情况?使用Java多线程工具类实现一个高效的线程池,并解释其背后的原理。结合观察者模式与Java并发框架,设计一个可扩展的事件处理系统
73 1
|
6月前
|
消息中间件 算法 NoSQL
面试题Kafka问题之Kafka保证系统的可用性如何解决
面试题Kafka问题之Kafka保证系统的可用性如何解决
51 0
|
7月前
|
Java Linux Android开发
Android面试题之说说系统的启动流程(总结)
这篇文章概述了Android系统的启动流程,从Boot Rom到Zygote进程和SystemServer的启动。init进程作为用户级别的第一个进程,负责创建文件目录、初始化服务并启动Zygote。Zygote通过预加载资源和创建Socket服务,使用fork函数生成SystemServer进程。fork过程中,子进程继承父进程大部分信息但具有独立的进程ID。Zygote预加载资源以减少后续进程的启动时间,而SystemServer启动众多服务并最终开启Launcher应用。文中还讨论了为何从Zygote而非init或SystemServer fork新进程的原因。
94 2
|
6月前
|
设计模式 存储 缓存
Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
67 0

热门文章

最新文章