数据库死锁解决办法

1.之前遇到过一个场景:有一个用户登录一直失败,但是其他用户却可以正常登录,后来测试借口发现在登录时更新这个用户的登录时间时,一直没有反应然后超时了。因为innordb是行级锁的所以就想到了是这条用户的信息被锁住了。

2.解决方案:

执行语句:SELECT * FROM information_schema.INNODB_TRX\G ;

*************************** 1. row ***************************
trx_id: 189324
trx_state: RUNNING
trx_started: 2013-04-18 17:48:14
trx_requested_lock_id: NULL
trx_wait_started: NULL
trx_weight: 3
trx_mysql_thread_id: 16
trx_query: NULL
trx_operation_state: NULL
trx_tables_in_use: 0
trx_tables_locked: 0
trx_lock_structs: 2
trx_lock_memory_bytes: 376
trx_rows_locked: 3
trx_rows_modified: 1
trx_concurrency_tickets: 0
trx_isolation_level: REPEATABLE READ
trx_unique_checks: 1
trx_foreign_key_checks: 1
trx_last_foreign_key_error: NULL
trx_adaptive_hash_latched: 0
trx_adaptive_hash_timeout: 10000
trx_is_read_only: 0
trx_autocommit_non_locking: 0

这个语句是查询innordb的事务信息的数据,一般trx_started这个时间到现在时间很长的话,说明这个事务已经锁死了,trx_rows_locked代表的是有多少行被锁定了。trx_tables_locked表示多少表被锁定了。所以可以根据这个信息去找到trx_mysql_thread_id的值然后使用kill 线程id 杀掉对应的线程就可以解开锁定了

转载于:https://www.cnblogs.com/wzk1992/p/5735459.html

解决资源死锁的最快办法是使用数据库管理系统提供的死锁检测和解决工具。以下是一些常见的方法: 1. 死锁检测:数据库管理系统通常提供了用于检测死锁的工具和命令。你可以使用这些工具来查看当前的死锁情况,了解哪些会话或事务被锁定,以及导致死锁的资源。根据数据库管理系统的不同,这些工具可能被称为死锁图、死锁监视器等。 2. 强制死锁解决:在某些情况下,你可以手动干预并解决死锁。这可以通过终止一个或多个造成死锁的会话或事务来实现。但请注意,这种方法可能会导致数据不一致或丢失,请在操作之前确保你了解其影响。 3. 优化查询和事务:死锁通常发生在复杂的查询和事务中,其中涉及到多个资源的并发访问。通过优化查询、减少事务长度、避免长时间持有资源等方法,可以减少死锁的发生概率。 4. 调整数据库配置参数:某些数据库管理系统允许你调整配置参数来减少死锁的产生。例如,可以调整并发连接数、锁定超时时间等参数,以适应你的应用程序需求。 5. 使用事务隔离级别:根据你的应用程序需求,选择适当的事务隔离级别也可以减少死锁的发生。例如,将事务隔离级别设置为读已提交或可重复读,可以减少死锁的机会。 请注意,死锁是一个复杂的问题,解决方法可能因数据库管理系统、应用程序设计和具体环境而有所不同。如果你遇到严重的死锁问题,建议咨询数据库管理员或专业的数据库咨询服务以获取更精确的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值