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

前言

        在现代数据密集型应用程序的开发和部署中,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解决死锁线程后,再做更改、重启服务

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring 5源码学习

文章目录 一. 访问[spring官网], 找到Spring Framework&#xff0c;点击红色标记github仓库&#xff0c;下载对应的分支代码&#xff0c;本人下载5.1.x二. 安装gradle三. 调整spring-framework配置四. 开始编译五.导入idea 一. 访问[spring官网], 找到Spring Framework&#xf…

使用Python和wxPython下载视频封面

介绍&#xff1a; 在在线视频内容的世界中&#xff0c;是领先的平台。拥有数十亿的视频&#xff0c;拥有引人注目的封面图像非常重要&#xff0c;以吸引观众。在本博客文章中&#xff0c;我们将探讨如何使用Python和wxPython模块下载视频封面。我们将提供两个代码示例&#xff…

图像数据做并行规约时,如何确定共享内存和网格的大小

做并行规约时&#xff0c;如何确定共享内存和网格的大小 1、为什么要确定共享内存和网格大小2、共享内存大小定义3、网格大小 注&#xff1a;1、这里记录使用笔记&#xff0c;不对cuda的名词做解释&#xff0c;没有详细数学原理和代码。 2、环境&#xff1a;cuda8.0&#xff0c…

密码学 | Random Oracle 随机预言机

​ &#x1f951;原文&#xff1a;究竟什么才是随机预言机呢&#xff1f; - 玄星的回答 &#x1f951;答主指出&#xff1a; 英文维基明明对 随机预言机 给出了两个完全不同的理解&#xff0c;但这两个理解之间的连接词却是 “Stated differently”&#xff0c;即 “换句话说…

STM32通过ESP8266(MQTT)连接新版ONENET(2024/4/23)(保姆级教程)附运行结果

⏩ 大家好哇&#xff01;我是小光&#xff0c;想要成为系统架构师的嵌入式爱好者。 ⏩在各种嵌入式系统中我们经常会使用上位机去做显示&#xff0c;本文对STM32通过ESP8266连接最新版的ONENET做一个详细教程。 ⏩感谢你的阅读&#xff0c;不对的地方欢迎指正。 STM32通过ESP82…

【图说】VMware Ubuntu22.04 详细安装教程

前言 无论是从事 Linux 开发工作&#xff0c;还是希望电脑运行双系统&#xff0c;VMware 虚拟机都是我们日常工作不可或缺的工具。本章将会重点介绍 VMware 安装流程&#xff0c;以及在 VMware 上如何运行、使用 Ubuntu22.04 系统。 一、VMware 下载安装 1.1 VMware 官网下载…

如何查看西门子触摸屏的镜像版本?

如何查看西门子触摸屏的镜像版本? 当软件组态的设备版本和实际设备镜像之间版本不同时,那么在传输项目时就会出现兼容性冲突的提示。 镜像版本说明: 如何调整镜像版本(升级或降级)? 为了使用新功能以及提高面板的稳定性、可靠性和可用性,建议使用新的镜像版本。 一、 通…

目标检测算法是指什么?

一、目标检测算法是指什么&#xff1f; 目标检测算法是计算机视觉领域的一个重要分支&#xff0c;它旨在识别和定位图像中的目标对象。以下是目标检测算法的相关内容&#xff1a; 目标检测的核心问题&#xff1a;目标检测需要解决的两个核心问题是“目标是什么”和“目标在哪里…

【计算机网络】(三)物理层 - 通信基础

文章目录 【计算机网络】&#xff08;三&#xff09;物理层 - 通信基础前言3.1 物理层的基本概念3.2 数据通信的基础知识3.2.1 数据、信号、码元3.2.2 信源、信宿、信道3.2.3 编码、调制3.2.3.1 基带调制&#xff08;编码&#xff09;3.2.3.2 带通调制&#xff08;调制&#xf…

想搭建跨境电商网站?掌握这些源码关键点,助您轻松上线

随着全球化的发展和电子商务的兴盛&#xff0c;跨境电商已成为企业拓展国际市场的主要方式之一。然而&#xff0c;想要搭建一个成功的跨境电商网站并非易事&#xff0c;其中关键之一就是掌握跨境电商网站源码的要点。在本文中&#xff0c;我将为您深入探讨如何选择、优化和维护…

一个java项目中,如何使用sse协议,构造一个chatgpt的流式对话接口

前言 如何注册chatGPT&#xff0c;怎么和它交互&#xff0c;本文就不讲了&#xff1b;因为网上教程一大堆&#xff0c;而且你要使用的话&#xff0c;通常会再包一个算法服务&#xff0c;用来做一些数据训练和过滤处理之类的&#xff0c;业务服务基本不会直接与原生chatGPT交互。…

mysql-connector-java和spring-boot-starter-jdbc和mybatis-spring-boot-start

mysql-connector-java和spring-boot-starter-jdbc和mybatis-spring-boot-start JDBC是什么意思&#xff1f; JDBC是使用java语言操作mysql数据库的规范&#xff0c;java语言必须按照这个规范写才可以操作mysql数据库。 mysql-connector-java 在最开始的时候 程序中是不允许…

省级客运、货运量及周转量数据(1990-2022年)

1、数据介绍 客运量和货运量是衡量交通运输行业发展状况的重要指标&#xff0c;可以反映一个地区或国家的经济发展水平和人民生活水平。而周转量则是反映运输行业效率的指标&#xff0c;即货物或旅客被运输的总距离。 省级客运、货运量及周转量是衡量一个地区交通运输行业发展…

第⑮讲:Ceph集群管理与监控操作指南

文章目录 1.查看集群的状态信息2.动态的查看集群的状态信息3.查看集群的利用率4.查看OSD的资源利用率5.查看OSD的列表6.查看各组件的状态7.查看集群的仲裁信息8.查看/修改集群组件sock的配置参数 1.查看集群的状态信息 通过集群状态信息可以看到集群的健康状态、各个组件的运行…

uniapp app权限说明弹框2024.4.23更新

华为上架被拒绝 用uni-app开发的app&#xff0c;上架华为被拒&#xff0c;问题如下&#xff1a; 您的应用在运行时&#xff0c;未见向用户告知权限申请的目的&#xff0c;向用户索取&#xff08;电话、相机、存储&#xff09;等权限&#xff0c;不符合华为应用市场审核标准。…

Bingbong的回文路径

Here 利用回文串&#xff0c;从左往右与从右往左的hash值相同来判断从左往右&#xff0c;例&#xff1a;从右往左&#xff0c;例&#xff1a;由于在树上&#xff0c;考虑建两颗树&#xff0c;一颗根为最高位&#xff08;up&#xff09;&#xff0c;一棵根为最低位&#xff08;…

0 transformers入门,HuggingFace!

目录 1 了解 2 文本分类 1 了解 1 依赖安装 !pip install transformers -i https://pypi.tuna.tsinghua.edu.cn/simple some-package 2 了解transformers 能做什么 from transformers.pipelines import SUPPORTED_TASKS SUPPORTED_TASKS.items()2 文本分类 我没外网所以…

微信小程序 讯飞录音 点击按钮录音内容转文字

<page-meta page-style"{{ showPolish ? overflow: hidden; : }}" /> <view class"wrap"> <view class"header-tab" style"justify-content: {{typeList.length > 2 ? start : center}}"><view class&quo…

promise笔记

1.介绍 之前的异步编程都是回调函数&#xff08;数据库操作、ajax、定时器、fs读取文件 &#xff09; promise是es6异步编程新的解决方案&#xff0c;是一个构造函数 优点&#xff1a;支持链式调用&#xff0c;可以解决回调地狱&#xff0c;可以指定回调函数 2.使用 functio…

UnicodeDecodeError: ‘utf-8‘ codec can‘t decode byte 0xd7

安装mamba时报错 检查报错原因&#xff1a; file -i ~/.bashrc file -i ~/.profile发现bashrc的编码不正确 对编码格式进行修改 iconv -f ISO-8859-1 -t UTF-8 ~/.bashrc > ~/.bashrc.utf8 mv ~/.bashrc.utf8 ~/.bashrc cp ~/.bashrc ~/.bashrc.backup执行完指令之后再安…