如何查看死锁?

1.可以通过 jstack 命令来进行查看,jstack 命令中会显示发生了死锁的线程
2.或者两个线程去操作数据库时,数据库发生了死锁,这是可以查询数据库的死锁情况.
SQL:
1、查询是否锁表
show OPEN TABLES wtere In_use 》e;
2、查询进程
show processlist;
3、查看正在锁的事务
SELECT * EROM INFORMATION_SCHEMA.INNODB_LOCKS;
4、查看等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS.

死锁通常发生在并发程序中,当两个或更多的线程互相等待对方释放资源而无法继续执行时,就会发生死锁。这种情况通常出现在以下几种条件同时满足的情况下: 1. **互斥**(Mutual Exclusion):至少有一个资源被进程独占,其他进程不能同时访问该资源。 2. **持有并等待**(Resource Holding and Wait):已经获得了一个资源的进程正在等待获取另一个资源,但该资源已被其他进程持有。 3. **不可抢占**(No Preemption):进程一旦获得了某个资源,除非进程自己主动释放,否则其他进程不能强行夺走。 4. **循环等待**(Cycle Wait):存在一个进程等待链,每个进程都在等待下一个进程所持有的资源。 要预防死锁,可以采取以下策略: 1. **避免嵌套请求**:尽量减少一个进程申请多个资源的顺序依赖,如果必须,确保按相同的顺序获取所有资源。 2. **设置超时机制**:为资源请求设置一个时间限制,超过这个时间还未获取到所需的全部资源就放弃并回滚已有的资源。 3. **资源预分配**:在开始任务前预先分配所有可能需要的资源,减少资源竞争。 4. **使用死锁检测算法**:定期检查是否有死锁发生,如银行家算法,当检测到可能的死锁时提前进行干预。 5. **按照固定的资源获取顺序**:让所有线程按照同样的顺序获取资源,破坏循环等待的条件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值