MySQL数据库运维:运行监控及解决sql执行死锁问题

news2024/11/26 10:40:40

前言

        在现代数据密集型应用程序的开发和部署中,MySQL数据库的运维是至关重要的环节之一。一个良好设计和维护的MySQL数据库系统可以确保数据的准确性、可靠性和高效的访问,从而支持业务的顺利运行。然而,随着业务规模的增长和复杂性增加,MySQL数据库也面临着诸多挑战,如性能瓶颈、死锁问题等。这些问题可能导致系统的无响应,影响业务的正常运行,甚至引发数据的不一致和丢失。

        在本篇博客中,我们将探讨MySQL数据库运维中的两个关键方面:运行监控和解决SQL执行死锁问题。首先,我们将介绍如何通过监控MySQL数据库的运行状态,了解各个数据库和表的使用情况、性能瓶颈以及潜在问题。其次,我们将深入探讨MySQL数据库中死锁的成因及其影响,并提供有效的方法和策略来解决SQL执行中的死锁问题。

运行监控 

        直接上干货吧!

# 数据库大小:检查每个数据库的磁盘占用量

SELECT table_schema AS "Database", 
ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) AS "Size in MB" 
FROM information_schema.tables 
GROUP BY table_schema;

# 表的数量和大小:观察每个数据库中各个表的数量和大小,这可以帮助您了解数据分布。

SELECT table_schema AS "Database", table_name AS "Table", 
ROUND((data_length + index_length) / 1024 / 1024, 2) AS "Size in MB" 
FROM information_schema.tables 
WHERE table_schema = 'your_database_name'
ORDER BY (data_length + index_length) DESC;

# 查询性能:使用 SHOW PROCESSLIST 查看当前正在执行的查询,以及它们的状态和持续时间,这有助于识别潜在的性能瓶颈。

SHOW FULL PROCESSLIST;

# 资源使用:查看数据库的CPU和内存使用情况,可以使用操作系统的工具,如Linux的top或htop,或者使用MySQL的性能监控工具。

# 访问频率和类型:通过分析日志文件或使用查询统计,了解哪些表被频繁访问以及查询类型(如SELECT, UPDATE, INSERT等)。

# 安全和访问控制:检查谁可以访问数据库及其权限设置。

 

解决sql执行死锁

        如果MySQL中出现了锁表导致无响应的情况,可以采取以下步骤来解决

1、查看当前锁信息 

        首先,可以使用以下命令查看当前的锁情况,找出是哪些进程或事务导致了数据库的锁定,通过这个命令可以看到当前正在执行的查询和事务,以及它们的状态和持续时间。

SHOW FULL PROCESSLIST;

         示例:

        当表死锁时,会出现Command会出现一些一直执行的动作,很多情况是sql导致,因此,你可以观察info中的sql语句(如果你早知道是什么sql导致的话)。

        或者,通过如下方法进一步定位问题所在:

        State(状态)字段:观察每个线程的状态,特别关注处于"Locked"、“Waiting for table level lock”、"Waiting for metadata lock"等表示锁定状态的线程。这些线程可能是由于死锁或锁等待而被阻塞的。

        Command(命令)字段:查看每个线程正在执行的SQL命令,如SELECT、UPDATE、INSERT、DELETE等。某些命令可能更容易导致死锁,例如UPDATE和DELETE语句会涉及到行级锁,容易与其他事务产生冲突。

        Time(执行时间)字段:观察每个线程的执行时间,长时间运行的线程可能是死锁的候选者,因为它们可能在等待锁资源而无法继续执行。

        Info(信息)字段:某些线程可能在Info字段中包含了额外的信息,例如正在等待的资源或执行的具体操作,这些信息有助于识别是否与死锁有关。

        ID(线程ID)字段:线程ID可以帮助您跟踪和区分不同的线程,当您发现死锁问题时,可以通过线程ID来定位具体的线程并进行进一步分析。

 

2、终止长时间运行的查询或事务

        根据上面定位到的ID值,杀死导致死锁的执行线程 

# <thread_id>是你所需要杀死的线程ID
KILL <thread_id>;

 

3、优化查询和事务 或 避免与正在执行的业务冲突

        回归本质,为什么会造成死锁呢?十有八九就是资源请求冲突,同一时间增删改查等事务的执行顺序冲突

         因此,为了避免死锁,首要条件就是减少资源请求冲突,避免长时间占用和结构变更

        ①优化长时间运行的查询或事务,确保它们不会频繁地持有锁或造成数据库阻塞。可以通过优化索引、减少查询范围或调整事务隔离级别等方法来改善性能。

        ②定期监控数据库性能,调整数据库配置参数,如锁定级别、连接数、缓冲池大小等,以减少锁的竞争和数据库阻塞。 

        ③避免设计长时间运行的事务,尽量将事务拆分成更小的单元,减少锁定时间和资源占用。

        ④不要贸然更改高占用的表结构,若更改时出现死锁并无法继续读取该表,需先断开现有服务,使用kill解决死锁线程后,再做更改、重启服务

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1625941.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【threejs教程7】threejs聚光灯、摄影机灯和汽车运动效果

【图片完整效果代码位于文章末】 在上一篇文章中我们实现了汽车模型的加载&#xff0c;这篇文章主要讲如何让汽车看起来像在运动。同时列出聚光灯和摄像机灯光的加载方法。 查看上一篇&#x1f449;【threejs教程6】threejs加载glb模型文件&#xff08;小米su7&#xff09;&…

5分钟——测试搭建的springboot接口(二)

5分钟——测试搭建的springboot接口&#xff08;二&#xff09; 1. 查看数据库字段2. 测试getAll接口3. 测试add接口4. 测试update接口5. 测试deleteById接口 1. 查看数据库字段 2. 测试getAll接口 3. 测试add接口 4. 测试update接口 5. 测试deleteById接口

RocketMQ 消息重复消费

现象 触发消息后&#xff0c;在1s内收到了两次消息消费的日志。 消息消费日志重复&#xff0c;reconsumeTimes0&#xff0c;主机实例也不同&#xff0c;说明是同一条消息被消费了两次 分析 生产者发送消息的时候使用了重试机制&#xff0c;发送消息后由于网络原因没有收到MQ…

【vue,unapi】UniApp引入全局js实现全局方法,全局变量

创建一个全局文件utils.js export const baseUrl "https://www.baidu.com/"export const fn () > {console.log("demo"); } export const obj {baseUrl : "https://www.baidu.com/",demo(){console.log("demo2");} }第一种&#…

2024 OceanBase 开发者大会:OceanBase 4.3正式发布,打造近PB级实时分析数据库

4月20日&#xff0c;2024 OceanBase开发者大会盛大召开&#xff0c;吸引了50余位业界知名的数据库专家和爱好者&#xff0c;以及来自全国各地的近600名开发者齐聚一堂。他们围绕一体化、多模、TP与AP融合等前沿技术趋势展开深入讨论&#xff0c;分享场景探索的经验和最佳实践&a…

人事管理软件全面盘点:2024年十款热门推荐!

随着企业规模的扩大和业务的多元化&#xff0c;人事管理变得越来越复杂。为了帮助企业更有效地管理人力资源&#xff0c;市场上出现了一系列主流的人事管理软件。 本篇文章为您盘点十款2024年值得关注的人事管理软件&#xff1a;Zoho People、北森、i人事、薪人薪事、肯耐珂萨…

鸿蒙开发使用云数据库的坑

在使用华为官网提供的CloudDBZoneWrapper.js有个坑&#xff0c; CloudDBZoneWrapper.js需要使用两个包 const clouddb require(hw-agconnect/database-server/dist/index.js); const agconnect require(agconnect/common-server); const path require(path);/*配置区域 */…

Java后台开发的前置说明

1.知识点逻辑 一个部分 都是先挑重点知识点讲解 然后根据这些重点知识点去完成一个项目的开发 然后在到返回来解决这个部分其他细枝末节的知识点 2.软件开发的分工 我们大致可以将软件开发分成四块&#xff1a; 1.前端开发(比如开发电脑中的京东 htmlcssjavascript) 2.移动开…

HarmonyOS开发实战(黑马健康系列一:欢迎页)

系列文章目录 &#xff08;零&#xff09;鸿蒙HarmonyOS入门&#xff1a;如何配置环境&#xff0c;输出“Hello World“ &#xff08;一&#xff09;鸿蒙HarmonyOS开发基础 &#xff08;二&#xff09;鸿蒙HarmonyOS主力开发语言ArkTS-基本语法 &#xff08;三&#xff09;鸿蒙…

Windows 10 使用 Vagrant 快速创建虚拟机

一、下载 Vagrant 官网地址&#xff1a;Oracle VM VirtualBox 阿里云盘&#xff1a;阿里云盘分享 二、安装 Vagrant 安装软件前请先确认 CPU 是否开启了虚拟化&#xff0c;要求开启 2.1、双击运行可执行文件后点击下一步 2.2、选择安装路径&#xff0c;为了避免中文乱码产生的…

AIGC技术带来的安全与隐私问题探讨

如何看待AIGC技术&#xff1f; 简介&#xff1a;探讨AIGC技术的发展现状和未来趋势。提醒&#xff1a;在发布作品前&#xff0c;请把不需要的内容删掉。 方向一&#xff1a;技术应用 机遇和挑战 AIGC国内场景应用图谱 方向二&#xff1a;伦理与风险 垄断与隐私风险 AI民主化诉…

蛋白质致病突变的计算方法(七)

6 识别治病突变 致病突变受到蛋白质稳定性、氢键模式、动态折叠、功能和关键生物特性变化的影响。因此&#xff0c;SIFT 、PolyPhen 、MutationTaster 和Cscape等计算方法使用基于结构、序列和网络的特征来预测蛋白质编码的单核苷酸变体对蛋白质结构表型的影响。此外&#xff…

随手记:树结构翻页和定位指定数据逻辑

业务背景&#xff1a; 树形组件展示数据&#xff0c;数据包含过去数据&#xff0c;现在数据&#xff0c;未来数据&#xff0c;用户在首次进入页面时&#xff0c;展示的是当天的数据&#xff0c;如果当天没有数据&#xff0c;则显示最近一条的过去数据。数据按照时间越长数据会…

用 Pytorch 训练一个 Transformer模型

昨天说了一下Transformer架构&#xff0c;今天我们来看看怎么 Pytorch 训练一个Transormer模型&#xff0c;真实训练一个模型是个庞大工程&#xff0c;准备数据、准备硬件等等&#xff0c;我只是做一个简单的实现。因为只是做实验&#xff0c;本地用 CPU 也可以运行。 本文包含…

python 脚本头(PyCharm+python头部信息、py头部信息、python头信息、py头信息、py文件头部)

文章目录 参考PyCharm设置脚本头头部信息 参考 https://developer.aliyun.com/article/1166544 https://blog.csdn.net/Dontla/article/details/131743495 https://blog.csdn.net/dongyouyuan/article/details/54408413 PyCharm设置脚本头 打开pycharm&#xff0c;点击file–…

深入了解MySQL:从基础到特性,全面解读关系数据库管理系统的历史与应用

文章目录 1. MySQL简介1.1 概述1.2 架构与兼容性1.3 开源与社区支持 2. MySQL的历史2.1 创始与初衷2.2 发展历程2.3 在Oracle的持续发展2.4 开源与商业结合 3. MySQL的核心特性4. MySQL在实际应用中的作用4.1 网站建设与内容管理4.2 商业智能与客户关系管理4.3 企业级应用与云集…

【大数据】分布式数据库HBase

目录 1.概述 1.1.前言 1.2.数据模型 1.3.列式存储的优势 2.实现原理 2.1.region 2.2.LSM树 2.3.完整读写过程 2.4.master的作用 1.概述 1.1.前言 本文式作者大数据系列专栏中的一篇文章&#xff0c;按照专栏来阅读&#xff0c;循序渐进能更好的理解&#xff0c;专栏…

解锁3D技术文档创建新可能,提升跨部门沟通效率

随着制造业的蓬勃发展与数字化转型的持续推进&#xff0c;产品设计与制作部门间的协作与沟通显得愈发关键。然而&#xff0c;传统沟通方式存在的效率低下、信息传递失准等弊端&#xff0c;已成为制约产品设计、制作效率和质量的瓶颈。 与此同时&#xff0c;CAD软件作为产品设计…

Scala 04 —— Scala Puzzle 拓展

Scala 04 —— Scala Puzzle 拓展 文章目录 Scala 04 —— Scala Puzzle 拓展一、占位符二、模式匹配的变量和常量模式三、继承 成员声明的位置结果初始化顺序分析BMember 类BConstructor 类 四、缺省初始值与重载五、Scala的集合操作和集合类型保持一致性第一部分代码解释第二…

海外云服务对比: AWS、GCP、Azure 与 DigitalOcean

云计算市场持续增长&#xff0c;预计到2030年将达到 2432.87 亿美元。在这个庞大的市场中&#xff0c;三家云服务提供商——亚马逊&#xff08;AWS&#xff09;、谷歌云平台&#xff08;GCP&#xff09;和微软Azure——共占云市场份额的64%。当用户选择云服务提供商来托管他们的…