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

《100个“反常识”经验12:死锁日志怎么看?》

本期摘要数据库突然卡死应用日志里一堆“Deadlock found”。你遇到过吗死锁不是Bug是并发事务资源竞争的正常现象。本文不讲复杂的死锁理论直接带你读MySQL死锁日志怎么看事务1在等什么锁、事务2拿着什么锁、谁被回滚了。看完你就能在三分钟内定位到问题SQL而不是盲目重启。一次让人想砸键盘的故障业务高峰期突然大量接口超时。应用日志里全是textDeadlock found when trying to get lock; try restarting transaction登录MySQL执行sqlSHOW ENGINE INNODB STATUS\G找到 LATEST DETECTED DEADLOCK 这一段。看到日志的瞬间两眼一黑——全是十六进制地址和晦涩的锁信息根本不知道在说什么。死锁日志到底在说什么一条典型的死锁日志长这样sql*** (1) TRANSACTION: TRANSACTION 310479085, ACTIVE 12 sec starting index read mysql tables in use 1, locked 1 LOCK WAIT 2 lock struct(s), heap size 1136, 1 row lock(s) *** (1) WAITING FOR THIS LOCK TO BE GRANTED: RECORD LOCKS space id 104 page no 45 n bits 80 index idx_user_id of table db.orders trx id 310479085 lock_mode X locks rec but not gap waiting *** (2) TRANSACTION: TRANSACTION 310479086, ACTIVE 10 sec starting index read mysql tables in use 1, locked 1 4 lock struct(s), heap size 1136, 3 row lock(s) *** (2) HOLDS THE LOCK(S): RECORD LOCKS space id 104 page no 45 n bits 80 index idx_user_id of table db.orders trx id 310479086 lock_mode X locks rec but not gap *** (2) WAITING FOR THIS LOCK TO BE GRANTED: RECORD LOCKS space id 104 page no 52 n bits 80 index idx_status of table db.orders trx id 310479086 lock_mode X locks rec but not gap waiting *** (2) ROLLBACK TO SAVE POINT拆开来看每个字段都有含义字段含义对我们有用的信息TRANSACTION 310479085事务ID区分两个事务ACTIVE 12 sec事务活跃时间超过几秒就要警惕waiting for this lock在等哪个锁告诉你被卡在哪个索引上holds the lock(s)持有哪些锁告诉你对方占了什么index idx_user_id索引名称定位到具体表和索引tabledb.orders表名哪个表出问题了ROLLBACK谁被回滚了事务2被干掉事务1继续两分钟定位问题的思路第一步找到事务1等什么看 (1) WAITING FOR THIS LOCK它被卡在idx_user_id上在等一个行锁。第二步找到事务2占什么看 (2) HOLDS THE LOCK(S)它占着idx_user_id上的锁同时在等idx_status上的锁。第三步得出结论事务1需要 user_idxxx 的锁事务2占着它不放同时事务2又在等另一条记录的锁。循环等待。第四步回看业务代码两个事务的SQL分别是事务1sqlUPDATE orders SET status paid WHERE user_id 123 AND order_id 456;事务2sqlUPDATE orders SET status shipped WHERE status paid AND order_id 456;事务1先锁住了 user_id 索引事务2锁住了 order_id 索引互相等待。如何解决临时方案kill掉被回滚的事务对应的应用连接释放锁。永久方案统一事务内的SQL顺序让所有事务按相同顺序访问表和索引优化索引减少行锁范围拆分大事务缩短锁持有时间使用 READ COMMITTED 隔离级别减少间隙锁快速排查脚本sql-- 查看当前锁等待 SELECT * FROM information_schema.innodb_lock_waits; -- 查看当前事务 SELECT * FROM information_schema.innodb_trx WHERE trx_state LOCK WAIT;下期预告《100个“反常识”经验13凌晨3点我误把生产当测试》

相关文章:

《100个“反常识”经验12:死锁日志怎么看?》

本期摘要数据库突然卡死,应用日志里一堆“Deadlock found”。你遇到过吗?死锁不是Bug,是并发事务资源竞争的正常现象。本文不讲复杂的死锁理论,直接带你读MySQL死锁日志:怎么看事务1在等什么锁、事务2拿着什么锁、谁被…...

为什么99%的Python工程师还没用上Python 3.15的并行解释器?,从PEP 703到生产环境灰度部署全链路避坑手册

更多请点击: https://intelliparadigm.com 第一章:Python 3.15并行解释器的演进本质与核心突破 Python 3.15 引入了原生支持的**多子解释器并发执行模型(PEP 703)**,标志着 CPython 运行时从“全局解释器锁&#xff0…...

单调栈入门到精通:每日温度 柱状图中最大的矩形

目录 一、入门题:739. 每日温度(中等) 题目描述 核心思路:单调栈的本质 代码实现(Java) 复杂度分析 二、进阶题:84. 柱状图中最大的矩形(困难) 题目描述 核心思路…...

【VS Code Dev Containers 性能调优黄金法则】:20年云原生开发专家亲授,实测启动提速3.8倍、内存降低62%的7大硬核配置技巧

更多请点击: https://intelliparadigm.com 第一章:Dev Containers 性能调优的底层逻辑与评估体系 Dev Containers 的性能瓶颈往往并非来自容器本身,而是源于宿主机资源调度、文件系统挂载策略、网络命名空间隔离强度以及 VS Code Remote-SSH…...

别再瞎调参数了!Vivado FFT IP核配置保姆级避坑指南(附仿真源码)

Vivado FFT IP核实战:从参数配置到结果分析的完整避坑手册 在数字信号处理领域,快速傅里叶变换(FFT)是实现频域分析的核心算法。对于FPGA开发者而言,Vivado提供的FFT IP核既是一个强大的工具,也是一个充满陷…...

物理AI推动人机协作迈向新阶段研究报告凯捷 2026_01

这份凯捷 2026 年《物理 AI:推动人机协作迈向新阶段》报告核心结论:物理 AI 正让机器人从预编程工具变成可感知、自适应、能学习的现实世界智能合作者,已到规模化拐点,将重构各行业生产力与人机协作模式。一、核心定义&#xff1a…...

免费音乐下载终极指南:轻松获取全网音乐资源的完整教程

免费音乐下载终极指南:轻松获取全网音乐资源的完整教程 【免费下载链接】MusicDownload 歌曲下载 项目地址: https://gitcode.com/gh_mirrors/mu/MusicDownload 想要随时随地畅听喜爱的音乐却受限于网络环境?MusicDownload作为一款完全免费开源的…...

3分钟搞定音乐标签乱码:Music Tag Web繁简转换实战指南

3分钟搞定音乐标签乱码:Music Tag Web繁简转换实战指南 【免费下载链接】music-tag-web 音乐标签编辑器,可编辑本地音乐文件的元数据(Editable local music file metadata.) 项目地址: https://gitcode.com/gh_mirrors/mu/music…...

【收藏备用|2026年版】小白程序员必看!企业AI转型避坑+大模型从入门到实战全套指南

本文整理了华夏基石人工智能咨询专家潘晓蕾的企业AI转型实战干货,结合2026年大模型行业最新趋势,针对当前企业AI转型中最易踩的五大误区,搭配六大可直接落地的破解方案,融合真实万亿级企业转型案例,帮小白快速读懂企业…...

【2026年版|建议收藏】小白/程序员转型AI工程师,6个月从入门到落地全路线图

现在一提到“AI 工程师”,很多小白和程序员的第一反应都是“从零训练百亿参数大模型”,下意识觉得门槛高到遥不可及,甚至直接望而却步。但2026年行业的真实需求恰恰相反——目前市场最紧缺的,是能基于现有大模型,快速搭…...

[Rust][ARM64] 九、ARM Trusted Firmware(ATF)——信任链与 PSCI

系列进度 第八篇:加载下一阶段(SD 卡 + jump_to) 第九篇(本文):ARM Trusted Firmware(ATF) 第十篇:移植 Rust OS 什么是 ARM Trusted Firmware? ARM Trusted Firmware(现更名为 Trusted Firmware-A,TF-A)是一个开源的 AArch64 固件参考实现,由 ARM 官方维护。它…...

[Rust][ARM64] 八、加载下一阶段——从 SD 卡读取内核并移交控制权

系列进度 第七篇:中断处理与异常向量表 第八篇(本文):加载下一阶段(SD 卡 + jump_to) 第九篇:ARM Trusted Firmware(ATF) BootROM 的最终使命 一个完整的裸机 BootROM 流程: GPU 固件(start4.elf)└→ 加载 kernel8.img 到 0x80000└→ 我们的裸机 BootROM├ 初始…...

[Rust][ARM64] 七、中断处理与异常向量表

系列进度 第六篇:MMU 与页表 第七篇(本文):中断处理与异常向量表 第八篇:加载下一阶段(SD 卡 + jump_to) AArch64 异常模型 AArch64 把所有"打断正常执行流"的事件统称为异常(Exception),分四类: 类型 说明 例子 同步异常 执行指令时产生,立即触发 缺页…...

【2026最新】五一假期远程办公神器:3分钟搞定企业内网接入的终极指南

五一假期倒计时!远程办公必备神器EasyConnect全攻略 随着五一假期临近,你是否也在盘算着如何优雅地提前离开办公室,或是晚几天再回到工位?别急!今天要介绍的这款企业级远程接入神器EasyConnect,将让你实现…...

Py-Scrcpy-Client编译性能优化:5种高效解决方案深度解析

Py-Scrcpy-Client编译性能优化:5种高效解决方案深度解析 【免费下载链接】py-scrcpy-client 项目地址: https://gitcode.com/gh_mirrors/py/py-scrcpy-client 在Android设备镜像开发领域,Py-Scrcpy-Client作为基于Python的屏幕镜像客户端&#x…...

智能代理搜索能力评估:DeepWideSearch框架解析

1. DeepWideSearch:智能代理搜索能力的基准测试框架在信息爆炸的时代,如何让AI系统像人类一样进行深度思考和广泛检索,成为智能代理(Agent)技术的核心挑战。DeepWideSearch正是为解决这一问题而设计的基准测试框架&…...

视觉语言模型个性化技术:CoViP框架解析与应用

1. 视觉语言模型个性化技术现状与挑战视觉语言模型(Vision-Language Models, VLMs)作为多模态人工智能的核心技术,近年来在图像描述生成、视觉问答等任务上取得了显著进展。然而,现有模型在个性化场景中仍面临根本性挑战——无法有…...

DeepSeek开源项目成功之道:技术策略与社区运营

1. 深度拆解DeepSeek现象级成功的三大支柱去年偶然在GitHub Trending看到DeepSeek项目时,其星标增长速度让我这个老开源人都感到震惊。这个最初由几名工程师发起的项目,在短短半年内就成长为该领域基础设施级别的存在。经过对其发展轨迹的复盘&#xff0…...

5分钟快速上手:FanControl风扇控制软件的终极中文指南

5分钟快速上手:FanControl风扇控制软件的终极中文指南 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa…...

Windows 10安卓子系统高效安装指南:无需升级Win11的完整解决方案

Windows 10安卓子系统高效安装指南:无需升级Win11的完整解决方案 【免费下载链接】WSA-Windows-10 This is a backport of Windows Subsystem for Android to Windows 10. 项目地址: https://gitcode.com/gh_mirrors/ws/WSA-Windows-10 还在为Windows 10无法…...

论文降重新纪元:书匠策AI,一键解锁学术纯净秘籍

在学术探索的征途中,论文写作无疑是一座巍峨的山峰,而降重与去除AIGC(人工智能生成内容)痕迹,则是攀登这座山峰时必须跨越的两道险峻关卡。传统降重方法,如同在迷雾中摸索前行,既耗时又费力&…...

OMR转换时间时区后返回

class ConvertTZ(Func):function CONVERT_TZoutput_field models.DateTimeField()# 支持多种调用方式def __init__(self, expression, from_tz, to_tz):super(ConvertTZ, self).__init__(expression,Value(from_tz),Value(to_tz))使用 F() 表达式或字段名进行时区转换 在 Dj…...

FloPy:Python地下水流建模的终极指南

FloPy:Python地下水流建模的终极指南 【免费下载链接】flopy A Python package to create, run, and post-process MODFLOW-based models. 项目地址: https://gitcode.com/gh_mirrors/fl/flopy FloPy 是一个强大的 Python 包,专门用于创建、运行和…...

如何用Revelation光影包打造电影级Minecraft世界:终极配置指南

如何用Revelation光影包打造电影级Minecraft世界:终极配置指南 【免费下载链接】Revelation An explorative shaderpack for Minecraft: Java Edition 项目地址: https://gitcode.com/gh_mirrors/re/Revelation 想让你的Minecraft方块世界瞬间升级为电影大片…...

ESPIRE:机器人空间推理评估新基准

1. 项目概述:空间推理基准ESPIRE的设计理念在机器人操作和具身智能领域,空间推理能力是智能体与物理世界交互的基础核心。传统评估方法主要依赖静态图像的多选题测试(如VQA),这种范式存在三个根本性缺陷:首…...

FineCat-NLI:动态注意力与对抗训练提升NLI性能

1. 项目概述FineCat-NLI这个项目名称直译为"精细分类-自然语言推理",从命名就能看出其核心目标:通过精细化的分类方法提升自然语言推理(NLI)编码器的性能表现。NLI作为自然语言处理(NLP)领域的基…...

Sigil插件系统技术解析:Python驱动的电子书编辑自动化框架

Sigil插件系统技术解析:Python驱动的电子书编辑自动化框架 【免费下载链接】Sigil Sigil is a multi-platform EPUB ebook editor 项目地址: https://gitcode.com/gh_mirrors/si/Sigil Sigil作为一款跨平台的EPUB电子书编辑器,其插件系统基于Pyth…...

DMVAE:基于分布匹配的变分自编码器改进方法

1. DMVAE:突破传统VAE限制的分布匹配新范式在计算机视觉领域,变分自编码器(VAE)长期以来面临着"Tokenizer困境"——如何在保持图像重建质量的同时,使潜在空间具备良好的可建模性。传统VAE采用高斯先验的KL散…...

3分钟搞定重复工作:KeymouseGo鼠标键盘自动化终极指南

3分钟搞定重复工作:KeymouseGo鼠标键盘自动化终极指南 【免费下载链接】KeymouseGo 类似按键精灵的鼠标键盘录制和自动化操作 模拟点击和键入 | automate mouse clicks and keyboard input 项目地址: https://gitcode.com/gh_mirrors/ke/KeymouseGo 你是否厌…...

AI Agent失败率20%的真相:工程分层才是关键,而非提示词

文章指出AI Agent失败率高的原因并非提示词不佳,而是工程分层没做对。文章提出了三层工程体系:Prompt Engineering(与模型沟通)、Context Engineering(信息流管理)和Harness Engineering(系统可…...