深入探讨MySQL锁机制

 2022-10-27    372  

MySQL锁机制究竟是怎样的呢?这是很多人都提到过的问题,下面就为您详细介绍MySQL锁机制方面的知识,希望可以让您MySQL锁机制有更多的了解。

当前MySQL已经支持 ISAM, MyISAM, MEMORY (HEAP) 类型表的表级锁了,BDB 表支持页级锁,InnoDB 表支持行级锁。 很多时候,可以通过经验来猜测什么样的锁对应用程序更合适,不过通常很难说一个锁比别的更好,这全都要依据应用程序来决定,不同的地方可能需要不同的锁。 想要决定是否需要采用一个支持行级锁的存储引擎,就要看看应用程序都要做什么,其中的查询、更新语句是怎么用的。例如,很多的web应用程序大量的做查询,很少删除,主要是基于索引的更新,只往特定的表中插入记录。采用基本的MySQL MyISAM 表就很合适了。 MySQL中对表级锁的存储引擎来说是释放死锁的。避免死锁可以这样做到:在任何查询之前先请求锁,并且按照请求的顺序锁表。 MySQL中用于 WRITE(写)的表锁的实现机制如下: 如果表没有加锁,那么就加一个写锁。 否则的话,将请求放到写锁队列中。 MySQL中用于 READ(读)的表锁的实现机制如下: 如果表没有加写锁,那么就加一个读锁。 否则的话,将请求放到读锁队列中。 当锁释放后,写锁队列中的线程可以用这个锁资源,然后才轮到读锁队列中的线程。 这就是说,如果表里有很多更新操作的话,那么 Select 必须等到所有的更新都完成了之后才能开始。 从 MySQL 3.23.33 开始,可以通过状态变量 Table_locks_waited 和 Table_locks_immediate 来分析系统中的锁表争夺情况: mysql> SHOW STATUS LIKE ‘Table%’; +———————–+———+ | Variable_name | Value | +———————–+———+ |Table_locks_immediate | 1151552 | | Table_locks_waited | 15324 | +———————–+———+

深入探讨MySQL锁机制

在 MySQL 3.23.7(在Windows上是3.23.25)以后,在 MyISAM 表中只要没有冲突的 Insert 操作,就可以无需使用锁表自由地并行执行 Insert 和 Select 语句。也就是说,可以在其它客户端正在读取 MyISAM 表记录的同时时插入新记录。如果数据文件的中间没有空余的磁盘块的话,就不会发生冲突了,因为这种情况下所有的新记录都会写在数据文件的末尾(当在表的中间做删除或者更新操作时,就可能导致空洞)。当空洞被新数据填充后,并行插入特性就会自动重新被启用了。 如果想要在一个表上做大量的 Insert 和 Select 操作,但是并行的插入却不可能时,可以将记录插入到临时表中,然后定期将临时表中的数据更新到实际的表里。可以用以下命令实现: mysql> LOCK TABLES real_table WRITE, insert_table WRITE; mysql> Insert INTO real_table Select * FROM insert_table; mysql> TRUNCATE TABLE insert_table; mysql> UNLOCK TABLES; InnoDB 使用行级锁,BDB 使用页级锁。对于 InnoDB 和 BDB 存储引擎来说,是可能产生死锁的。这是因为 InnoDB 会自动捕获行锁,BDB 会在执行 SQL 语句时捕获页锁的,而不是在事务的开始就这么做。 行级锁的优点有: 在很多线程请求不同记录时减少冲突锁。 事务回滚时减少改变数据。 使长时间对单独的一行记录加锁成为可能。 行级锁的缺点有: 比页级锁和表级锁消耗更多的内存。 当在大量表中使用时,比页级锁和表级锁更慢,因为他需要请求更多的所资源。 当需要频繁对大部分数据做 GROUP BY 操作或者需要频繁扫描整个表时,就明显的比其它锁更糟糕。 使用更高层的锁的话,就能更方便的支持各种不同的类型应用程序,因为这种锁的开销比行级锁小多了。 表级锁在下列几种情况下比页级锁和行级锁更优越: 很多操作都是读表。 在严格条件的索引上读取和更新,当更新或者删除可以用单独的索引来读取得到时: Update tbl_name SET column=value Where unique_key_col=key_value; Delete FROM tbl_name Where unique_key_col=key_value; Select 和 Insert 语句并发的执行,但是只有很少的 Update 和 Delete 语句。 很多的扫描表和对全表的 GROUP BY 操作,但是没有任何写表。 表级锁和行级锁或页级锁之间的不同之处还在于: 将同时有一个写和多个读的地方做版本(例如在MySQL中的并发插入)。也就是说,数据库/表支持根据开始访问数据时间点的不同支持各种不同的试图。其它名有:时间行程,写复制,或者是按需复制。

  •  标签:  
  • MySQL
  •  

原文链接:https://77isp.com/post/4582.html

=========================================

https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。