当前位置: 首页 > article >正文

面试官:爆火视频点赞每秒 10w,数据库行锁直接卡死,你怎么破?

最近有个兄弟去面某短视频大厂前面的架构设计聊得挺嗨结果面试官最后抛出一个看似简单的“点赞”题直接把他问到了自闭。面试官“现在有个爆火视频比如春晚刘谦变魔术一秒钟有 10 万人同时点赞。你代码里写 UPDATE video_statistics SET like_count like_count 1 WHERE video_id 1001;数据库会发生什么”兄弟“那就加 Redis 缓存啊异步写库。”面试官冷笑“如果这 10 万人都点赞同一个视频Redis 的单 Key 会被打爆Hot Key吗异步写库时如果 MQ 消费者还是一条条更新数据库的行锁排队能解决吗”这兄弟支支吾吾半天没答上来。其实这道题考的不是“点赞”而是高并发架构中极其硬核的“写热点Write Hotspot”问题。今天 Fox 带你三步拆解教你如何用架构师的思维优雅地消除数据库行锁地雷。第一招青铜回答——直接操作数据库自杀式打法很多人的第一反应是数据库不是有索引吗直接更新不就行了-- 看起来人畜无害的 SQL UPDATE video_statistics SET like_count like_count 1 WHERE video_id 1001;Fox 深度解析这是典型的“行锁地雷”。在 InnoDB 引擎中更新这一行必须获取排他锁X 锁。当 10 万个请求同时涌入时数据库内部会发生以下惨剧行锁竞争只有一个线程能拿到锁其余 99,999 个线程全部进入等待队列。上下文切换随着队列变长操作系统的 CPU 资源会全部浪费在线程的唤醒和挂起上。死锁检测MySQL 内部的死锁检测机制会疯狂扫描这个巨大的等待队列导致 CPU 瞬时飙升到 100%。结论在高并发面前单行更新就是系统的死穴。此时的吞吐量TPS会掉到个位数。第二招黄金回答——Redis 计数 异步落库稍微有点经验的会说不能直接压数据库得用内存挡一下。方案利用 Redis 的 INCR 命令点赞先在 Redis 里加 1然后通过 MQ 异步同步回 MySQL。瓶颈如果是超级热点比如热搜第一10w QPS 全部压在 Redis 的一个 Key 上单机 Redis 吞吐量也会到极限。而且如果 MQ 消费端依然是“拿一条消息、调一次 1 库操作”数据库的行锁压力依然没有任何缓解只是把压力从前端推迟到了后端。第三招王者回答——多级分层聚合 批量写合并真正的工业级方案核心思想只有四个字分而治之。1. 接入层本地缓冲Local Coalescing不要让每一个点赞都变成一次网络请求策略在 Web Server 的内存里利用 AtomicLong 开辟一个 200ms 的时间窗口。效果这 200ms 内的 500 次点赞在内存里直接合并成一个“点赞 500”的请求再发给后端服务。2. Redis 热点 Key 拆分Sharding模仿 Java 中 LongAdder 的设计思想。策略将 video_id_9527 拆分成多个子 Keycount:9527:1、count:9527:2 ... count:9527:10。分流请求按用户 ID 取模分散到不同的 Key 和不同的 Redis 节点上。查询查总数时把所有子 Key 的值求和即可3. 消费端批量写合并Batch Update—— 绝杀行锁这是解决数据库行锁的终极手段。操作MQ 消费者开启批量消费一次取 500 条消息在内存里按 video_id 进行聚合。执行最终在数据库里只执行一条合并后的 SQL-- 将 500 次锁竞争转化为 1 次 SQL 执行 UPDATE video_statistics SET like_count like_count 500 WHERE video_id 1001;由于加锁频率降低了三个数量级数据库的行锁竞争瞬间消失吞吐量原地起飞。面试满分模板直接背诵面试官“如何设计一个支撑 10w QPS 点赞的热点系统”你“我会采取‘层层聚合异步合并’的架构端侧聚合利用本地内存做微小的窗口聚合如 100ms将高频散点请求转化为低频批量请求减少 RPC 调用。缓存分片针对热点 Key采用Redis 计数器分片方案将写压力分摊到多个分片规避单点 Hot Key 问题。批量写合并这是核心。通过 MQ 异步削峰并在消费端实现批量聚合。将同一行数据的多次更新在内存中累加最终以一次 UPDATE ... SET count count N 的形式更新数据库。容灾兜底配合定期快照和 Binlog 日志确保在追求极致性能的同时满足最终一致性。”写在最后架构师的价值就在于面对“物理限制”如行锁、IOPS时能够利用内存和异步化手段把矛盾转移。

相关文章:

面试官:爆火视频点赞每秒 10w,数据库行锁直接卡死,你怎么破?

最近有个兄弟去面某短视频大厂,前面的架构设计聊得挺嗨,结果面试官最后抛出一个看似简单的“点赞”题,直接把他问到了自闭。 面试官: “现在有个爆火视频,比如春晚刘谦变魔术,一秒钟有 10 万人同时点赞。你…...

适合Bootstrap初学者的五个开源实战项目

...

如何在按需导入类时动态执行其内部代码

本文介绍如何利用 Python 3.7 的 __getattr__ 钩子机制,实现“仅在显式导入某个类时才执行其初始化逻辑”,避免模块级类定义时的副作用触发。 本文介绍如何利用 python 3.7 的 __getattr__ 钩子机制,实现“仅在显式导入某个类时才执行其…...

企业级自动化测试架构设计:Chrome for Testing 实现30%测试效率提升的完整方案

企业级自动化测试架构设计:Chrome for Testing 实现30%测试效率提升的完整方案 【免费下载链接】chrome-for-testing 项目地址: https://gitcode.com/gh_mirrors/ch/chrome-for-testing Chrome for Testing 是Google专门为Web应用测试和自动化场景设计的Chr…...

3个元数据管理难题,如何用可视化工具优雅解决?

3个元数据管理难题,如何用可视化工具优雅解决? 【免费下载链接】ExifToolGui A GUI for ExifTool 项目地址: https://gitcode.com/gh_mirrors/ex/ExifToolGui 照片元数据管理常常让人望而生畏:面对数百张旅行照片需要统一调整拍摄时间…...

ConvLSTM核心代码逐行解读:从PyTorch实现到自定义数据集加载的避坑指南

ConvLSTM核心代码逐行解读:从PyTorch实现到自定义数据集加载的避坑指南 时空序列预测是计算机视觉和深度学习领域的重要课题。ConvLSTM作为传统LSTM的扩展,通过引入卷积操作,能够同时捕捉时间和空间维度的特征。本文将深入解析ConvLSTM的PyTo…...

Smithbox终极指南:零基础打造你的专属魂系游戏世界

Smithbox终极指南:零基础打造你的专属魂系游戏世界 【免费下载链接】Smithbox Smithbox is a modding tool for Elden Ring, Armored Core VI, Sekiro, Dark Souls 3, Dark Souls 2, Dark Souls, Bloodborne and Demons Souls. 项目地址: https://gitcode.com/gh_…...

DevOps CI/CD完整流水线实战:从代码提交到生产部署

摘要现代软件开发的核心竞争力在于持续交付能力。一个完善的CI/CD流水线能够将代码从开发者的本地环境安全、可靠、高效地输送到生产环境。本文详细讲解完整的七阶段流水线:代码检查、单元测试、构建、安全扫描、集成测试、预发布、生产部署。通过GitHub Actions、K…...

LeetCode高频算法精讲:大厂面试知识体系完全指南

算法面试是互联网大厂招聘的核心环节,掌握高频题型和解题模板是通关关键。本文系统讲解LeetCode上的五大高频题型:二分查找、滑动窗口、DFS/BFS、动态规划和贪心算法。每种算法包含原理讲解、标准模板、变体应对和复杂度分析,配合大量完整代码…...

如何快速掌握NIF文件编辑:面向游戏开发者的完整NifSkope指南

如何快速掌握NIF文件编辑:面向游戏开发者的完整NifSkope指南 【免费下载链接】nifskope A git repository for nifskope. 项目地址: https://gitcode.com/gh_mirrors/ni/nifskope NifSkope是一款强大的开源工具,专门用于打开和编辑NetImmerse文件…...

【仅限首批技术负责人开放】:Gartner认证的「生成-审查」双闭环成熟度模型(含自评矩阵与6个月跃迁路径图)

第一章:智能代码生成与代码审查流程整合 2026奇点智能技术大会(https://ml-summit.org) 现代软件工程实践中,智能代码生成已不再孤立运行于开发环境边缘,而是深度嵌入持续集成与代码审查(CI/CR)主干流程。当开发者提交…...

为什么你的Copilot总“写偏”?揭秘LLM提示工程×IDE语义感知的4层对齐机制

第一章:智能代码生成与IDE集成方案 2026奇点智能技术大会(https://ml-summit.org) 现代开发工作流正经历由大语言模型驱动的范式迁移,智能代码生成已从实验性插件演进为IDE原生能力的核心组件。主流集成方案聚焦于低延迟响应、上下文感知补全与安全可控…...

2026届必备的十大AI学术网站解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 知网已正式推出AIGC检测服务系统,此系统目的在于识别学术文本里由人工智能生成的…...

2025届学术党必备的降重复率方案推荐榜单

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 要降低AIGC检测率,需从文本特征着手。首先,得对词汇多样性予以调整&…...

目前的人脸识别水平

这个图片需要稍微旋转手机才能识别出来,因为他脸比较小,而且他照片拍的时候就是有一定角度的,精准识别核心区域似乎只要是正面的脸,角度对,就没问题了。现在试试看侧面:一般情况应该是够用了。...

app找到人脸已经非常轻松了

缺陷: 从这个3个图片可以看出:他的人脸位置不准确: 第一个图片:下巴没有计算进去 第二个图片:额头不完整 第三个图:左边脸明显不完整。 也就是说现在的这个算法可能也就用来玩还是可以的。如果真的用于…...

避坑指南:osg与osgEarth版本搭配那些事儿,从编译失败到成功显示地球

三维地理可视化开发实战:OSG与osgEarth版本适配深度解析 引言:版本兼容性问题的普遍困境 在三维地理信息系统开发领域,OpenSceneGraph(OSG)和osgEarth的组合堪称黄金搭档,但许多开发者在环境搭建的第一步——编译环节就遭遇了滑铁…...

Alpine镜像构建卡在APKINDEX.tar.gz?可能是你的Dockerfile少了这行代码

Alpine镜像构建卡在APKINDEX.tar.gz?国内开发者必看的Dockerfile优化指南 当你满怀期待地执行docker build命令,却眼睁睁看着进度条卡在fetch http://dl-cdn.alpinelinux.org/alpine/v3.7/main/x86_64/APKINDEX.tar.gz这个步骤时,那种感觉就像…...

如何实现跨设备音频共享?Scream虚拟声卡网络传输终极指南

如何实现跨设备音频共享?Scream虚拟声卡网络传输终极指南 【免费下载链接】scream Virtual network sound card for Microsoft Windows 项目地址: https://gitcode.com/gh_mirrors/sc/scream 你是否曾想过将电脑音频无线传输到其他设备播放?无论是…...

D3KeyHelper终极指南:5分钟配置你的暗黑3自动技能宏

D3KeyHelper终极指南:5分钟配置你的暗黑3自动技能宏 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper 暗黑破坏神3的重复操作让你感到疲惫&…...

告别网络依赖!手把手教你下载并本地部署Mermaid.js(附完整HTML模板)

彻底告别网络依赖:零基础实现Mermaid.js本地化部署实战指南 在技术文档撰写、系统架构设计或项目汇报的场景中,可视化图表的重要性不言而喻。Mermaid作为一款基于文本描述的图表生成工具,凭借其简洁的语法和丰富的图表类型,已经成…...

现代密码学:理论与实践解答

现代密码学:理论与实践解答 本文还有配套的精品资源,点击获取 简介:在数字化时代,信息安全至关重要,而现代密码学是其核心保障。从基本加密解密到网络协议,清华大学《现代密码学》教材为学习者提供了深入…...

什么是逆向工程?

什么是逆向工程?逆向工程是解构、剖析和分析硬件设备、软件程序或系统以了解其内部工作原理、设计、漏洞和功能的过程;它也代表一把双刃剑。虽然它对开发人员来说是一个有用的工具,但在恶意行为者手中,逆向工程用于发现和利用应用…...

告别Spyder导入报错:Anaconda环境中PyTorch安装后的终极调试指南

告别Spyder导入报错:Anaconda环境中PyTorch安装后的终极调试指南 在数据科学和深度学习的世界里,PyTorch无疑是当前最受欢迎的框架之一。然而,许多初学者在成功安装PyTorch后,却常常在最后一步——在Spyder或Jupyter Notebook中导…...

别再只盯着模型权重量化了!深入拆解KV Cache量化如何成为LLM推理服务的‘降本增效’关键

KV Cache量化:解锁大模型推理服务的成本与性能平衡之道 在大型语言模型(LLM)的商业化部署浪潮中,企业技术团队正面临一个关键矛盾:如何在不牺牲服务质量的前提下,显著降低推理服务的运营成本?当…...

实战复盘:我是如何用R包SpiecEasi里的Sparcc,从土壤微生物数据中挖出关键互作关系的

从土壤微生物数据到共现网络:我的Sparcc实战经验分享 去年在研究连作障碍土壤微生物群落变化时,我遇到了一个棘手的问题:如何从海量的OTU数据中找出那些真正有生态学意义的微生物互作关系?经过反复尝试,最终通过SpiecE…...

从D触发器到13进制计数器:一个同步时序电路的设计实践

1. 从零开始理解D触发器 第一次接触D触发器时,我完全被这个小小的数字元件搞懵了。直到在实验室里亲手搭建了一个简单的电路,才真正理解它的精妙之处。D触发器全称Data触发器,是数字电路设计中最基础的存储单元之一,也是我们构建1…...

别再只会调库了!手把手教你用STM32的TIM3定时器,从零生成精准舵机PWM信号

从寄存器到舵机:深度解析STM32定时器生成PWM的底层逻辑 第一次尝试用STM32驱动舵机时,我盯着库函数生成的波形百思不得其解——为什么理论上1.5ms的脉宽,舵机却总是停在120度左右?这个问题困扰了我整整三天,直到我翻开…...

AI视觉检测:Jetson Orin vs RTX A2000 推理速度对比

Jetson Orin vs RTX A2000: 谁才是 AI 视觉检测的“真香”平台?“产线要部署 YOLOv8,该买 Orin 还是 A2000?” “Orin 功耗低但怕性能不够,A2000 强大但发热严重?” “同样是 Ampere 架构,推理速…...

STM32 低功耗睡眠模式(SLEEP)中断唤醒的实战配置与抗干扰优化

1. 低功耗模式入门:为什么需要SLEEP模式? 在嵌入式开发中,电池供电的设备最头疼的问题就是续航。我做过一个无线传感器项目,原本预计能用3个月的设备,实际测试一周就没电了。排查后发现是MCU一直在全速运行&#xff0c…...