MySQL 锁机制

锁机制: 解决因资源共享 而造成的并发问题。

示例: 买最后一件衣服


 

分类:

操作类型分:

  •  a.读锁(共享锁):对同一个数据 多个读操作可以同时进行 互不干扰
  •  b.写锁(互斥锁):如果当前写操作没有完毕() 则无法进行其他的读锁,写锁

操作范围分:

  •  a.表锁:一次性对一张表整体加锁。如MyISAM存储引擎使用表锁,开销小,加锁快:无死锁,但锁的范围大 容易发生锁冲突 并发度低
  •  b.行锁:一次性对一条数据加锁。 冲突概率低 如innoDB存储引擎使用行锁 开销大,加锁慢,容易出现死锁 锁的范围较小不易发生锁冲突,并发度高(很小概率 发生高并发问题:脏读,幻读,不可重复读,丢失更新)
  •  c.页锁

 

增加锁: lock table 表1 read/write ,表2 read/write

查看加锁的表: show open tables

ex:  lock table  tablelock read: 

 

 

如果某一个会话 对A表加了read锁 则该会话 可以对A表进行读操作,不能进行写操作; 且该会话不能对其他表进行读,写操作

即如果给A表加了读锁,则当前会话只能对A表进行读操作

其他会话:

 总结: 会话0给A表加了锁,其他会话的操作: 

 a.可以对其他表(A表以外的表)进行读,写操作

 b. 对A表 可以读,写需要等待释放锁;

 

释放锁:unlock tables;

 

加写锁:

当前会话可以的对加了写锁的表 进行任何操作  但是不能操作其他表

 其他会话: 对会话0中 加写锁的表 可以进行增删改查的前提是:等待会话0释放写锁

 

MySQL 锁机制_第1张图片

 

分析表锁定 show open tables : 1代表被加了锁

分析表锁定的严重程度: show status like 'tabel%';

table_locks_immediate :立刻能获取到的锁

table_locks_waited:需要等待的表锁数  如果该值越大 说明存在越大的锁竞争

一般建议: table_locks_immediate/table_locks_waited>5000 建议采用innoDB引擎 ,否则使用MyISAM引擎

 

ex:

   会话0: 写操作

MySQL 锁机制_第2张图片

解决办法: 要这个数据 就 commit  不要就 rollback

 

小结:

对行锁情况 要关闭自动提交

1如果会话x对某条数据a进行DML操作时  则其他会话必须等待会话x结束事务后 才能对数据进行操作

2.表锁是通过unlock tables : 行锁是通过事务解锁

MySQL 锁机制_第3张图片

行锁注意事项: 如果没有索引,则行锁会转为表锁

MySQL 锁机制_第4张图片

原因:通过索引列 则发生了类型转换 索引失效 因此此次操作 会从行锁转换为表锁。

 

行锁: innoDB默认采用行锁

缺点:比表锁性能损坏大

优点:并发能力强效率高;

建议: 高并发用innoDB 否则用MyISAM

 

行锁分析:

MySQL 锁机制_第5张图片

查询行锁

如果仅仅是查询数据,能否加锁 for update 。 通过for update 对query 语句进行加锁。

 

 

 

你可能感兴趣的:(MySQL)