mysql数据库使用MyISAM引擎老是卡死?MyISAM锁的介绍和实践

作者:admin 发布时间:2020-04-11 12:46:45 浏览:2092次
现在会写代码的,应该没人会不知道mysql吧?因为mysql数据库是免费的,被大量的运用于各种项目,那么自然性能就是大家最关注的,随着业务的增长,数据库的数量的不断增加,老是发现各种不愉快的事情,比如某某说查询个数据老半天出不来,某某又说,我怎么写不进数据库了?那么,今天就让小超越工作室带大家了解一下mysql数据库使用MyISAM引擎的锁机制吧,剖析一下导致mysql数据表卡死的问题。 mysql数据库使用MyISAM引擎老是卡死?MyISAM锁的介绍和实践

MyISAM引擎下如何设置表锁

MyISAM在执行查询语句(SELECT)前,会自动给涉及的所有表加读锁,我们不需要手动去做任何的操作!

MyISAM在执行更新操作 (UPDATE、DELETE、INSERT等)前,会自动给涉及的表加写锁,,我们不需要手动去做任何的操作,因此,只要给表设置myisam引擎,就可以了。


阻塞发生的场景

对MyISAM表读操作时候,不会阻塞其他用户对同一表的读请求,但会阻塞对同一表的写请求

对MyISAM表写操作,则会阻塞其他用户对该表的读写操作,当一个线程获得对一个表的写锁后可以对表进行更新操作,其他线程的读、写操作都会等待,直到锁被释放为止


接下来通过实践来观察下,对MyISAM表读操作时候,会如上面我们说的那样其他用户对该表的读请求不会阻塞,写请求会阻塞吗?

(先建立一张test表,存储引擎为myisam,字段为id,name,并插入几条数据)

(1)A窗口在select的时候特意暂停了12秒,然后立即去B窗口执行select,观察:

在A窗口查询没有结束之前,B窗口对该表进行查询,查询结果立刻出现,无需等待A窗口的查询结束
注:sleep(4)是每条数据暂停4秒的意思,如果select的结果数据有1条就会暂停4秒,有3条就会暂停12秒
(2)A窗口在select的时候特意暂停了12秒,然后立即去B窗口执行update,观察:
在查询没有结束之前,update更新操作是处于一直等待状态,查询结束之后,update操作才开始执行

(3)A窗口在select的时候特意暂停了12秒,然后立即去B窗口执行delete,观察:

在查询没有结束之前,delete删除操作是处于一直等待状态,查询结束之后,delete操作才开始执行

(4)A窗口在select的时候特意暂停了12秒,然后立即去B窗口执行insert,观察:

在查询没有结束之前,insert操作是处于一直等待状态,查询结束之后,insert操作才开始执行

经过上面的4个测试,我们可以看到myisam表在执行查询操作的时候,其他进程对该表的读操作没有影响,但是写操作(增删改查)会发生阻塞,直到第一个获得读锁的进程操作完成释放完读锁后,写操作才能进行。

MySQL数据库卡表问题分析并解决

如需转载请保留本文出处: https://zhe94.com/671.html

上一篇:快速建站之前言:如何建立一个自己的网站
下一篇:什么是MyISAM储存引擎中的表级锁(MySql数据库性能优化)
[uni-app]微信小程序隐私保护指引用户同意窗口代码

[uni-app]微信小程序隐私保护指引用户同意窗口代码

为规范开发者的用户个人信息处理行为,保障用户合法权益,微信要求开发者主动同步微信当前用户已阅读并同意小程序的隐私政策等收集使用规则,方可调用微信提供的隐私接口。
vscode右键运行插件—code runner

vscode右键运行插件—code runner

在VS Code里,能有一种快捷的方式来运行各类的代码,甚至是代码片段。就好了,Code Runner插件支持了 Node.js, Python, C++, Java, PHP, Perl, Ruby, Go等超过40种的语言。下面,我们就来看看如何来玩转Code Runner,提高你的效率。
php中的两个冒号是什么意思?例如Request::header('token')

php中的两个冒号是什么意思?例如Request::header('token')

在PHP中,双冒号(::)被称为范围解析操作符(Scope Resolution Operator),也有时被称为静态调用运算符。它用于引用类中的静态属性、静态方法或常量。
php __construct是什么意思

php __construct是什么意思

在PHP中,__construct是一个魔术方法(Magic Method),用于类的构造函数。当使用new关键字实例化一个对象时,会自动调用该方法。
thinkphp6.*版本的无缝升级到thinkphp8.0版本实操方法

thinkphp6.*版本的无缝升级到thinkphp8.0版本实操方法

ThinkPHP是一个免费开源的,快速、简单的面向对象的轻量级PHP开发框架,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP诞生十七年来一直秉承简洁实用的设计原则,在保持出色的性能和至简代码的同时,更注重易用性。
php出现SSL certificate problem: unable to get local issuer certificate的解决办法

php出现SSL certificate problem: unable to get local issuer certificate的解决办法

在PHP中使用cURL或其他网络操作时,可能会遇到一个常见的SSL证书问题,错误信息为“SSL certificate problem: unable to get local issuer certificate”。翻译过来的意思是:“SSL证书问题:无法获取本地颁发者证书”,这是因为PHP试图验证SSL证书,但是无法找到用来验证这些证书的CA(证书颁发机构)证书。