`
jiangduxi
  • 浏览: 456668 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

MySQL数据库的锁机制

阅读更多
MySQL5.1 支持对MyISAM和MEMORY表进行表级锁定,对InnoDB表进行行级锁定

  在大多数Web应用程序执行最多的可能是Search操作,而最少则可能是Delete操作,针对关键字的值进行Update,Insert少量具体的表。那么这种情况下,MySQL MyISAM的设置已经调节的很好

在MySQL中对于使用表级锁定的存储引擎,表锁定时不会死锁的。这通过一个查询开始就立即请求所有必要的锁定并且总是以同样的顺序锁定表来管理。

  对于WRITE, MySQL使用的表锁定方法的原理如下:
 
引用

    1. 如果在表上没有锁,在它上面放一个写锁。
     2. 否则,把锁定请求放在写锁定队列中。
 


  对于Read, MySQL使用的表锁定方法的原理如下:
 
引用

    1. 如果在表上没有写锁,把一个读锁放在它上面。
     2. 否则,把锁定请求放在读锁定队列中。
 

当一个锁定被释放时,锁定可被写锁定队列中的线程得到,然后是读锁定队列中的线程。
这意味着,如果你在一个表上有许多更新,Select语句将等待直到没有更多的更新。
如果Insert语句不冲突,可以自由为MyISAM表混合并行的INSERT和Select语句而不需要锁定。


InnoDB使用行锁定,BDB使用页锁定,对于这两种存储引擎,都可能存在死锁。这是因为,在SQL语句处理期间,InnoDB自动获得行锁定,BDB获得页锁定,而不是在事务启动时获得。

行级锁定的优点:
 
引用

    1. 当在许多线程中访问不同的行时只存在少量锁定冲突
    2. 回滚时只有少量的更改
    3. 可以长时间锁定单一的行
 


行级锁定的缺点:
 
引用

  1. 比页级或表级锁定占用更多的内存
  2. 当在表的大部分中使用时,比页级或表级锁定速度慢,因为你必须获取更多的锁
  3. 如果你在大部分数据上经常进行Group by 操作或者必须经常扫描整个表,比其它锁明显慢很多
  4. 用高级别锁定,通常支持不同的类型锁定,你也可以很容易地调节应用程序,因为其锁成本小于行级锁定。
 


如果表的大部分语句用于读取,对严格的关键字进行读取和更新,你可以更新或者删除,可以用单一的读取的关键字来提取一行;
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中使用GET_LOCK()和RELEASE_LOCK()。这些是建议性锁定,它们只能在运行良好的应用程序中工作。


为达到最高锁定速度,除InnoDB 和BDB 之外,对所有存储引擎,MySQL使用表锁定(而不是页、行或者列锁定)。对于InnoDB 和BDB 表,如果你用LOCK TABLES显式锁定表,MySQL只使用表锁定;如果你不使用LOCK TABLES,因为 InnoDB 使用自动行级锁定而BDB 使用页级锁定来保证事务隔离。

但是对于大表,对于大多数应用程序,表锁定比行锁定更好,但存在部分缺陷。表锁定使许多线程同时从一个表中进行读取操作,但如果一个线程想要对表进行写操作,它必须首先获得独占访问。更新期间,所有其它想要访问该表的线程必须等待直到更新完成。

表更新通常情况认为比表检索更重要,因此给予它们更高的优先级。这应确保更新一个表的活动不能“饿死”,即使该表上有很繁重的SELECT 活动。

表锁定在这种情况下会造成问题,例如当线程正等待,因为硬盘已满并且在线程可以处理之前必须有空闲空间。在这种情况下,所有想要访问出现问题的表的线程也被设置成等待状态,直到有更多的硬盘空间可用。

表锁定在下面的情况下也存在问题:

· 一个客户发出长时间运行的查询。

· 然后,另一个客户对同一个表进行更新。该客户必须等待直到SELECT完成。

· 另一个客户对同一个表上发出了另一个 SELECT 语句。因为UPDATE比 SELECT 优先级高,该SELECT 语句等待UPDATE完成,并且等待第1个 SELECT 完成。

下面描述了一些方法来避免或减少表锁定造成的竞争:

· 试图使 SELECT 语句运行得更快。可能必须创建一些摘要(summary)表做到这点。

· 用--low-priority-updates启动mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的第2个SELECT语句将在UPDATE语句前执行,而不需要等候第1个 SELECT 完成。

· 可以使用SET LOW_PRIORITY_UPDATES=1语句指定具体连接中的所有更新应使用低优先级。

· 可以用LOW_PRIORITY属性给与一个特定的INSERT、UPDATE或DELETE语句较低优先级。

· 可以用HIGH_PRIORITY属性给与一个特定的SELECT语句较高优先级。

· 为max_write_lock_count系统变量指定一个低值来启动mysqld来强制MySQL在具体数量的插入完成后临时提高所有等待一个表的SELECT 语句的优先级。这样允许在一定数量的WRITE锁定后给出READ锁定。

· 如果你有关于INSERT结合SELECT的问题,切换到使用新的MyISAM表,因为它们支持并发的SELECT和INSERT。

· 如果你对同一个表混合插入和删除,INSERT DELAYED将会有很大的帮助。

· 如果你对同一个表混合使用 SELECT 和DELETE 语句出现问题,DELETE 的LIMIT 选项可以有所帮助。

· 对 SELECT 语句使用SQL_BUFFER_RESULT可以帮助使表锁定时间变短。

· 可以更改mysys/thr_lock.c中的锁代码以使用单一的队列。在这种情况下,写锁定和读锁定将具有相同的优先级,对一些应用程序会有帮助。

这里是一些MySQL中表锁定相关的技巧:

· 如果不混合更新与需要在同一个表中检查许多行的选择,可以进行并行操作。

· 可以使用 LOCK TABLES 来提高速度,因为在一个锁定中进行许多更新比没有锁定的更新要快得多。将表中的内容切分为几个表也可以有所帮助。

· 如果在MySQL中表锁定时遇到速度问题,可以将表转换为 InnoDB 或BDB 表来提高性能。
分享到:
评论

相关推荐

    mysql数据库英文文献.pdf

    MySQL数据库架构还包括查询优化器、缓存机制、锁机制等多个组件。 MySQL数据库架构的优点包括: * 高性能: MySQL数据库架构能够提供高性能的数据存储和查询功能。 * 灵活性: MySQL数据库架构能够支持多种存储...

    MySQL 数据库锁定机制

    ### MySQL 数据库锁定机制 #### 一、概览 MySQL 数据库锁定机制是数据库系统中一项重要的技术,用于处理多用户并发访问同一份数据时可能产生的冲突问题。MySQL 支持多种类型的锁定机制,包括行级锁定、表级锁定...

    MySQL数据库锁机制原理解析

    在并发访问情况下,很有可能出现不可重复读等等读现象。为了更好的应对高并发,封锁...乐观锁和悲观锁不仅在关系数据库里应用,在Hibernate、Memcache等等也有相关概念。 悲观锁:也即悲观并发控制,Pessimistic Concur

    MySQL8.0锁机制和事务

    MySQL 8.0 中的锁机制和事务是数据库系统中非常重要的概念。锁机制是指数据库系统中对数据访问的控制机制,而事务是指数据库系统中的一组操作单元。了解锁机制和事务是非常关键的,因为它们直接影响着数据库系统的...

    MySQL高级 锁机制

    MySQL的锁机制是数据库管理系统中用于控制并发操作的重要机制,对于多用户环境下的数据一致性、事务隔离性和系统性能有着至关重要的影响。本文将深入探讨MySQL的高级锁机制,包括表锁和行锁,并提供一些优化建议。 ...

    MySQL数据库原理及设计方法.pdf

    MySQL数据库是一种广泛使用的开源关系型数据库管理系统,其原理和设计方法是数据库管理员和开发者必须掌握的基础知识。本文将深入探讨MySQL的逻辑架构、并发控制、事务处理等方面。 首先,MySQL的逻辑架构分为三层...

    C++连接mysql数据库 源代码

    需要注意的是,MySQL数据库的线程安全性和锁机制也是需要考虑的因素。 7. **数据库设计**: 在编写源代码前,理解数据库的表结构、字段类型以及它们之间的关系至关重要。良好的数据库设计能够提升数据的存储效率和...

    数据库锁机制详解:Java中实现与最佳实践

    数据库锁机制是确保数据一致性和完整性的重要手段。在Java中,通过理解不同类型的锁及其用途,可以有效地实现数据库锁,优化数据库性能,并避免死锁等问题。合理使用锁机制,可以提高数据库的并发处理能力,保障数据...

    mysql数据库锁+优化.pdf

    MySQL数据库中的锁机制是事务处理和并发控制的关键部分,它确保了数据的一致性和完整性。在MySQL中,尤其是InnoDB存储引擎,锁主要用于处理多用户同时访问同一数据时可能出现的冲突。以下是对锁的一些详细解释: 1....

    MySQL数据库考试练习题 mysql试题集 共28页.pdf

    3. **锁机制**:熟悉不同的锁定级别(如读锁、写锁)及其对并发控制的影响。 ### 五、视图与存储过程 1. **视图的创建与使用**:了解视图的作用及其创建和使用方法。 2. **存储过程的编写**:掌握存储过程的语法...

    数据库中锁机制的学习

    本文将深入探讨数据库锁的基本概念、类型以及它们在实际应用中的作用。 首先,我们要理解锁的两种基本类型:共享锁(Shared Locks)和排他锁(Exclusive Locks)。共享锁允许一个事务读取一行数据,但不允许其他...

    MySQL的锁机制解析

    MySQL的锁机制是数据库管理系统中用于控制并发操作的重要机制,对于保证数据的一致性和完整性起着至关重要的作用。...通过深入学习和实践,我们可以更好地管理和维护MySQL数据库,提高系统整体效率。

    MySQL 数据库监控攻略

    - **监控建议**:尽可能使用行级锁机制,如InnoDB引擎;对于必须使用MyISAM的情况,则需关注锁的竞争情况。 ### 常用的MySQL监控工具 - **Percona Toolkit**:一套强大的开源工具集,用于监控、管理和诊断MySQL。 ...

    项目9--MySQL数据库中的事务机制与锁机制.pptx

    项目9--MySQL数据库中的事务机制与锁机制.pptx

    MySQL数据库:事务与锁机制

    ### MySQL数据库:事务与锁机制 #### 一、事务的基础概念与特性 ##### 1. 事务的概念 事务(Transaction)是数据库操作的基本单位。它确保了一组操作要么全部成功,要么全部失败,从而保持数据的一致性和完整性。...

    mysql insert锁机制1

    MySQL的Insert锁机制是数据库管理系统中确保数据一致性和并发控制的重要组成部分。在MySQL的InnoDB存储引擎中,插入操作不仅涉及到行级锁,还可能涉及Gap锁和Next-Key Locks,这些锁机制的设计是为了防止幻读...

    MySQL数据库性能监控与诊断

    - **锁等待**:数据库锁的等待时间和频率,反映并发控制的效率。 #### SQL运行 通过监控SQL运行情况,可以识别出执行效率低下或资源消耗大的SQL语句。这通常涉及到对慢查询日志的分析,以及对TopSQL的持续监控,以...

Global site tag (gtag.js) - Google Analytics