看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

一、什么是死锁

加锁(Locking)是数据库在并发访问时保证数据一致性和完整性的主要机制。任何事务都需要获得相应对象上的锁才能访问数据,读取数据的事务通常只需要获得读锁(共享锁),修改数据的事务需要获得写锁(排他锁)。当两个事务互相之间需要等待对方释放获得的资源时,如果系统不进行干预则会一直等待下去,也就是进入了死锁(deadlock)状态。

二、死锁产生的场景

1.数据库表准备

1.1. 创建数据库表

#创建数据库create database chuanzhi;#选择数据库use chuanzhi;#创建测试表CREATE TABLE `tb_heima` (  `id` INT NOT NULL,  `username` VARCHAR(45) NULL,  PRIMARY KEY (`id`));#插入测试数据INSERT INTO `tb_heima` (`id`, `username`) VALUES ('1', '传智教育-教育行业A股IPO第一股');

2.死锁场景演示

2.1. 打开一个dos窗口

mysql -u账号 -p密码,进入mysql命令行输入:

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

开启一个事务,mysql> begin;

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

执行更新语句,mysql> update tb_heima set username = 'heima' where id =1;

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

注意:此时更新是成功的,但并未提交事务。

2.2.再打开一个dos窗口

登录mysql,开启另一个事务操作同上。再次执行更新语句,mysql> update tb_heima set username = 'heima' where id =1;

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

注意:此时第二个窗口处于等待中,需要等待第一个窗口释放写锁才能执行成功。

等待一段时候后,第二个窗口报错了

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

注意:由于第一个窗口未提交事务,导致第二个窗口在等待一段时候后,超过锁定等待超时。

三、解决死锁问题

通过mysql客户端工具连接,按照以下步骤执行。

select * from information_schema.innodb_lock_waits; #锁等待的信息,可以看到堵塞和被堵塞者

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

注意:超过锁定等待超时后,此条记录会消失,也就是说正在阻塞的记录在此表才能查看到。

select * from information_schema.innodb_trx; # 查询锁事务状态信息

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

注意:查询出死锁后,得到trx_mysql_thread_id死锁的id。

kill sessionId; # 杀掉有问题的session

kill 15;kill 16;

再次执行select * from information_schema.innodb_trx; # 查询锁事务状态信息

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

注意:确认此表是否存在锁事务记录,如果没有则说明死锁问题已经解决。

四、如何避免死锁

对于数据库的多表操作时,尽量按照相同的顺序进行处理,尽量避免同时锁定两个资源,如操作A和B两张表时,总是按先A后B的顺序处理, 必须同时锁定两个资源时,要保证在任何时刻都应该按照相同的顺序来锁定资源。所有的update和delete操作必须走唯一索引SQL语句中不要使用太复杂的关联多表的查询;使用“执行计划”对SQL语句进行分析,对于有全表扫描的SQL语句,建立相应的索引进行优化。把SELECT放在Update语句前避免事务中的用户等待交互

文章来源于:王晴儿网页设计博客 欢迎分享交流,转载请注明出处

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/262674.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
黑马程序员黑马程序员订阅用户
上一篇 2023年5月10日 11:56
下一篇 2023年5月11日 15:59

相关推荐

  • mysql表的字段类型:字符串、日期时间、数值

    值型:存储的数值大小不一样,默认是有符号的,无符号:unsigned 整数:tinyint、smallint、int 小数:float、decimal float,范围大约是-3.4E+38到-1.1E-38、0和1.1E-38到3.4E+38 Decimal:定点型 Decimal(10,2):…

    2017年11月22日 MySQL自学教程
    0260
  • 聊聊探索1136服务器主机的性能改进与优化方法。

    服务器主机的性能改进与优化方法 随着互联网的快速发展,服务器主机的性能优化变得越来越重要,本文将介绍一些探索1136服务器主机性能改进与优化的方法,帮助您提高服务器的运行效率和稳定性。 1、硬件升级 硬件升…

    2024年7月14日
    00
  • asp虚拟主机管理的方法有哪些。

    ASP虚拟主机的管理方法主要包括利用控制面板、FTP、数据库管理工具和文件管理器等工具进行操作。控制面板是最常使用的方式,可以方便地进行各种网站设置的管理;FTP和API则适合有一定技术水平的用户和开发者,便于…

    2024年7月14日
    00
  • 轻松搭建宝塔服务器快速搭建网站的实用指南。

    宝塔服务器是一款免费的服务器管理软件,可以帮助用户快速搭建网站。您可以使用宝塔面板来安装LNMP环境,然后在宝塔面板上添加站点,使用宝塔面板可以搭建多个网站 。如果您是第一次使用宝塔面板,您需要先下载并安…

    2024年7月7日
    01
  • 小编教你navicat基本操作。

    Navicat是一款强大的数据库管理工具,它提供图形界面用于轻松管理远程数据库。使用Navicat,我们可以进行连接数据库、操作数据库、导入备份、查询数据、修改用户信息等基本操作。它也支持查看数据库版本和SQL执行计…

    2024年7月5日
    01
  • 说说sqlplus oracle。

    “使用sqlplus工具连接Oracle数据库。” Oracle数据库之SQLPLUS详解 SQLPLUS是Oracle数据库的一个命令行工具,它允许用户通过命令行界面与Oracle数据库进行交互,SQLPLUS提供了一种简单、灵活的方式来执…

    2024年7月17日
    00
  • 关于宝塔一键部署轻松实现利用部署及管理。

    宝塔一键部署,简化了服务器的利用、部署和管理过程。 在现代的软件开发和运维过程中,部署和管理是两个非常重要的环节,部署是将软件应用到生产环境的过程,而管理则是确保软件在生产环境中正常运行和维护的过程,…

    2024年7月10日
    00
  • 我来说说mysql删库。

    MySQL删库操作是指在MySQL数据库中删除一个或多个数据库,在执行此操作之前,请确保已经备份好相关数据,以防止误删,本文将介绍如何在MySQL中删除数据库,并提供一些建议和注意事项。 1. 使用DROP DATABASE语句删…

    2024年6月16日
    00

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息