mysql锁表

一、导致锁表的原因

1、锁表发生在insert update 、delete 中;

2、锁表的原理是 数据库使用独占式封锁机制,当执行上面的语句时,对表进行锁住,直到发生commite 或者 回滚 或者退出数据库用户;

3、锁表的原因 :

1)、A程序执行了对 tableA 的 insert ,并还未 commite时,B程序也对tableA 进行insert 则此时会发生资源正忙的异常 就是锁表;

2)、锁表常发生于并发而不是并行(并行时,一个线程操作数据库时,另一个线程是不能操作数据库的,cpu 和i/o 分配原则)

4、减少锁表的概率:
减少insert 、update 、delete 语句执行 到 commite 之间的时间。
具体点批量执行改为单个执行、优化sql自身的非执行速度
如果异常对事物进行回滚。

二、mysql锁表的解决

#查看进程id,然后用kill id杀掉进程
show processlist;

#查询正在执行的进程

SELECT * FROM information_schema.PROCESSLIST where length(info) >0 ;

#查询是否锁表

show OPEN TABLES where In_use > 0;

#查看被锁住的

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

#等待锁定

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

#杀掉锁表进程

kill id

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL锁表故障注入是指攻击者通过恶意构造的SQL语句来利用MySQL的锁机制造成数据库的故障或停止服务的情况。在MySQL中,锁表是通过表级锁或行级锁来实现的。 表级锁是MySQL中锁定粒度最大的一种锁,它对当前操作的整张表进行加锁。这种锁的实现相对简单,资源消耗也较少,加锁速度较快,并且不容易出现死锁。MyISAM和InnoDB存储引擎都支持表级锁。 行级锁是MySQL中锁定粒度最小的一种锁,它只针对当前操作的行进行加锁。行级锁可以大大减少数据库操作的冲突,提高并发度。但是,行级锁的加锁开销较大,加锁速度较慢,并且容易出现死锁。 在锁表故障注入中,攻击者利用恶意构造的SQL语句,通过触发锁冲突或死锁的方式来影响数据库的正常运行。例如,攻击者可以故意向一个表中插入大量数据,导致其他事务无法获取到该表的写锁,从而导致数据库的写操作被阻塞或超时。 为了防止锁表故障注入,可以采取以下措施: 1. 使用合理的数据库设计和索引优化,减少锁的竞争。 2. 避免长时间的事务和复杂的查询语句,尽量降低锁的持有时间。 3. 合理设置事务隔离级别,根据业务需求选择合适的隔离级别。 4. 监控数据库的锁等待情况,及时发现并解决潜在的锁问题。 5. 对于不必要的表锁,可以考虑使用行级锁来替代,提高并发度和性能。 总之,MySQL锁表故障注入是一种利用MySQL的锁机制来造成数据库故障或停止服务的攻击方式。为了防止这种攻击,需要合理设计数据库架构,优化查询语句,并合理设置事务隔离级别,以减少锁冲突和死锁的发生。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Mysql数据库总结](https://blog.csdn.net/jaredray/article/details/124080045)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值