| 全局锁就是对 整个数据库实例 加锁。当你需要让整个库处于 只读状态 的时候,可以使用这个命令,之后其他线程的以下语句会被阻塞: |
| 数据更新语句(数据的增删改)、数据定义语句(包括建表、修改表结构等)和更新类事务的提交语句。全局锁的典型使用 场景 是:做 全库逻辑备份 |
| |
| # 获取全局锁 |
| Flush tables with read lock |
| 死锁是指两个或多个事务在同一资源上相互占用,并请求锁定对方占用的资源,从而导致恶性循环 |
-
死锁产生条件

-
死锁案例
| # 用户A给用户B转账100,同时用户B给用户A转账100,这时可能发生死锁 |
| # 事务1先获取用户A的排他锁,减少100;事务2这时也获取用户B的排他锁,减少100 |
| # 这时事务1想获取用户B的排他锁,给B的账户增加100;同时事务2想获取用户A的排他锁,给用户A的账户增加100 |
| # 2个事务都想获取对方占有的锁,2个事务都需要等待对方先执行完后才能执行,这就是死锁 |

| |
| begin; |
| |
| update account set money=10 where id=1; |
| |
| |
| begin; |
| |
| update account set money=10 where id=2; |
| |
| |
| |
| update account set money=20 where id=2; |
| |
| |
| |
| update account set money=20 where id=1; |
| |
| |
| |
| # 方案1:直接进入等待,直到超时。这个超时时间可以通过参数innodb_lock_wait_timeout 来设置。如果将该参数设置的太短,会影响正常的阻塞 |
| # 方案2:发起死锁检测,发现死锁后,主动回滚死锁链条中的某一个事务(将持有最少行级排他锁的事务进行回滚), |
| 让其他事务得以继续执行。将参数 innodb_deadlock_detect 设置为on ,表示开启这个逻辑 |
- 避免死锁

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY