Java最新面试官:聊聊双11百亿流量「高并发秒杀系统」的设计思路,2024年Java技术下半场在哪

总结

谈到面试,其实说白了就是刷题刷题刷题,天天作死的刷。。。。。

为了准备这个“金三银四”的春招,狂刷一个月的题,狂补超多的漏洞知识,像这次美团面试问的算法、数据库、Redis、设计模式等这些题目都是我刷到过的

并且我也将自己刷的题全部整理成了PDF或者Word文档(含详细答案解析)

我的美团offer凉凉了?开发工程师(Java岗)三面结束等通知...

66个Java面试知识点

架构专题(MySQL,Java,Redis,线程,并发,设计模式,Nginx,Linux,框架,微服务等)+大厂面试题详解(百度,阿里,腾讯,华为,迅雷,网易,中兴,北京中软等)

我的美团offer凉凉了?开发工程师(Java岗)三面结束等通知...

算法刷题(PDF)

我的美团offer凉凉了?开发工程师(Java岗)三面结束等通知...

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

问题1:如何应对瞬时大流量高并发?


拿双十一的电商秒杀来说,系统能否承载瞬时大流量高并发就是一大难点。

高并发问题的解决思路是 分层过滤,分而治之。 即在不同的层次尽可能地过滤掉无效请求,让“漏斗”最末端的才是有效请求。

具体方法:

  1. 页面静态化

  2. 缓存预热

  3. 异步化

  4. 削峰值填谷,通过消息队列异步地创建订单

由于篇幅有限, 应对高并发的具体方法和代码实现 ,我会在《秒杀系统项目课》中详细讲解,感兴趣的同学可以前去免费试听一下~

问题2:有限库存,如何防止超卖?


因为秒杀的本质,就是对库存的抢夺。每个秒杀的用户来都去数据库查询库存校验库存,然后扣减库存,就可能导致数据库崩溃。

而MySQL 数据库单点能支撑 1000 QPS,但是 Redis 单点能支撑 10万 QPS。因此我们可以将库存信息加载到Redis中,将MySQL的访问压力转移到Redis上,直接通过 Redis 来判断并扣减库存。

实际上,微博、阿里巴巴、百度、美团、拼多多等都在使用Redis。 Redis如今是互联网项目的标配,在面试中非常高频被问到。 使用Redis的原理是:

  1. 缓存库存信息,大部分数据读取请求都被 Redis 挡住了,保护了MySQL

  2. 检查 Redis 库存和扣减 Redis 库存是两步操作,通过Lua脚本将这两步操作,合并成一个整体,保证原子操作性

  3. 哪怕 Redis 侧方行,可以创建订单了,到 MySQL 的时候也需要再检查一次。

问题3:如何保障系统稳定和高可用?


Q1:当秒杀的用户量超过预计,请求量超过服务器最大承载压力怎么办?

解决方案: 流量控制 (flow control),其原理是监控应用流量的 QPS 或并发线程数等指标,当达到指定的阈值时对流量进行控制,以避免被瞬时的流量高峰冲垮,保护系统不会被压垮,从而保障应用的高可用性。

2.服务熔断

Q2:当有服务出现故障,不可用时如何应对?

在互联网系统中,当下游服务因访问压力过大而响应变慢或失败,上游服务为了保护系统整体的可用性,可以暂时切断对下游服务的调用。

问题4:如何限制用户购买商品件数?


在限购场景中,系统需要针对用户购买商品次数进行限制,一个用户只能购买N个商品,达到限制购买数量户不能继续购买,防止黄牛党。

实现方法:

①直接查询数据库订单表,查询用户是否已经有购买成功的记录

但这种操作可能会带来这些问题:

最后

金三银四到了,送上一个小福利!

image.png

image.png

专题+大厂.jpg

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

需要这份系统化的资料的朋友,可以点击这里获取

  • 18
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值