Mysql的kill命令

article/2025/10/18 19:11:02

在MySQL中有两个kill命令:一个是kill query +线程id,表示终止这个线程中正在执行的语句;一个是kill connection +线程id,这里connection可缺省,表示断开这个线程的连接,当然如果这个线程有语句正在执行,也是要先停止正在执行的语句的。

kill并不是马上停止的意思,而是告诉执行线程说,这条语句已经不需要继续执行了,可以开始“执行停止的逻辑了”,例如释放锁。

当用户执行kill query thread_id_B时,MySQL里处理kill命令的线程做了两件事:

1. 把session B的运行状态改成THD::KILL_QUERY(将变量killed赋值为THD::KILL_QUERY);

2. 给session B的执行线程发一个信号。

第一步把状态置为THD::KILL_QUERY,但是可能线程当时正在等待锁之类的无法判断的状态的,所以就要发出一条信号。上面的分析中,隐含了这么三层意思:

1. 一个语句执行过程中有多处埋点,在这些埋点的地方判断线程状态,如果发现线程状态是THD::KILL_QUERY,才开始进入语句终止逻辑;

2. 如果处于等待状态,必须是一个可以被唤醒的等待,否则根本不会执行到埋点处;

3. 语句从开始进入终止逻辑,到终止逻辑完全完成,是有一个过程的。

线程没有执行到判断线程状态的逻辑

我们来看一个例子:

可以看到:

1. sesssion C执行的时候被堵住了;

2. 但是session D执行的kill query C命令却没什么效果,

3. 直到session E执行了kill connection命令,才断开了session C的连接,提示“Lost connection to MySQL server during query”

4. 但是这时候,如果在session E中执行show processlist,你就能看到下面这个图。

id=12这个线程的Commnad列显示的是Killed。客户端虽然断开了连接,但实际上服务端上这条语句还在执行过程中。

         在实现上,等行锁时,使用的是pthread_cond_timedwait函数,这个等待状态可以被唤醒。但是,在这个例子里,12号线程的等待逻辑是这样的:每10毫秒判断一下是否可以进入InnoDB执行,如果不行,就调用nanosleep函数进入sleep状态。

虽然12号线程的状态已经被设置成了KILL_QUERY,但是在这个等待进入InnoDB的循环过程中,并没有去判断线程的状态,因此根本不会进入终止逻辑阶段。而当session E执行kill connection 命令时,是这么做的,

1. 把12号线程状态设置为KILL_CONNECTION;

2. 关掉12号线程的网络连接。因为有这个操作,所以你会看到,这时候session C收到了断开连接的提示。

 

终止逻辑耗时较长

1. 超大事务执行期间被kill。这时候,回滚操作需要对事务执行期间生成的所有新数据版本做回收操作,耗时很长。

2. 大查询回滚。如果查询过程中生成了比较大的临时文件,加上此时文件系统压力大,删除临时文件可能需要等待IO资源,导致耗时较长。

3. DDL命令执行到最后阶段,如果被kill,需要删除中间过程的临时文件,也可能受IO资源影响耗时较久。

 

Ctril+C命令

执行Ctrl+C的时候,是MySQL客户端另外启动一个连接,然后发送一个kill query 命令。

 

表多连接就慢吗?

当使用默认参数连接的时候,MySQL客户端会提供一个本地库名和表名补全(使用Tab键)的功能。为了实现这个功能,客户端在连接成功后,需要多做一些操作:

1. 执行show databases

2. 切到db1库,执行show tables

3. 把这两个命令的结果用于构建一个本地的哈希表。

上面的第三步,是很花时间的,加上命令的-A可以跳过这个功能。加上–quick也可以跳过这个阶段。但是,–quick有一个问题,先看看mySQL客户端发送请求后,接收服务端返回结果的两种方式:

1. 一种是本地缓存,也就是在本地开一片内存,先把结果存起来。如果你用API开发,对应的就是mysql_store_result 方法。

2. 另一种是不缓存,读一个处理一个。如果你用API开发,对应的就是mysql_use_result方法。

       加上–quick参数,就会使用第二种不缓存的方式,这时如果本地处理得慢,就会导致服务端发送结果被阻塞,因此会让服务端变慢。


http://chatgpt.dhexx.cn/article/i6drX1J1.shtml

相关文章

kill与kill -9的区别

kill命令格式: kill -Signal pid pid是进程号,可以用 ps 命令查出 signal是发送给进程的信号, 默认参数下,kill 发送SIGTERM(15)信号给进程,告诉进程,你需要被关闭,请自…

Linux命令之终止进程kill

概述 kill 命令可以用来终止进程&#xff0c;即杀死某些进程。 语法 该命令的语法如下&#xff1a; kill [选项] 进程号该命令支持的选项有&#xff1a; 选项说明 -l <信息编号>若不加<信息编号>选项&#xff0c;则 -l 参数会列出全部的信息名称-a当处理当前进…

killall 、kill 、pkill 命令详解

转载地址&#xff1a;https://www.cnblogs.com/rsky/p/4886043.html killall 命令 Linux系统中的killall命令用于杀死指定名字的进程&#xff08;kill processes by name&#xff09;。我们可以使用kill命令杀死指定进程PID的进程&#xff0c;如果要找到我们需要杀死的进程&am…

kill命令详解kill -9、kill -15区别

kill相当于赐死&#xff0c;kill -9相当于斩立决 kill命令默认的信号就是15&#xff0c;也就是 kill -15 1.从help中可以清晰的看到 -n 指的是 信号编号 2.kill -l(查看Linux/Unix的信号变量) 3.说一下SIGKILL(kill -9)和SIGTERM(kill -15) kill -9 PID 是操作系统从内核级别…

Linux之kill命令

【Linux常用命令速查手册】关注【入门小站】&#xff0c;后台回复 「1001」 自取。 Linux中的kill命令用来终止指定的进程&#xff08;terminate a process&#xff09;的运行&#xff0c;是Linux下进程管理的常用命令。通常&#xff0c;终止一个前台进程可以使用CtrlC键&#…

(Linux)kill命令常用技巧

前言 在Linux的系统中&#xff0c;kill是我们最常见的命令之一。 kill&#xff0c;英语中为杀死的意思&#xff0c;顾名思义&#xff0c;就是用来杀死一些东西的命令&#xff0c;用来杀死系统中的进程。就像是Windows系统中的关闭软件的按钮或任务管理器的结束任务&#xff0c;…

Linux 进程kill -9 无法杀死解决方案

从下述案例中可以看到使用kill -9 28051并未将28051进程杀死 [rootiZufxxxxxxxxxxxx2tnZ devops-xxl-job]# kill -9 28051 [rootiZufxxxxxxxxxxxx2tnZ devops-xxl-job]# jps 28051 Launcher 29247 Jps [rootiZufxxxxxxxxxxxx2tnZ devops-xxl-job]# jps 28051 Launcher 29539 J…

常用的 kill 命令,来了解一下!

开发和运维&#xff0c;开发和测试基本上不分家。所以市面上存在很多的开发运维、运维开发、测试开发等岗位。如果你连 kill 命令都还不会&#xff0c;怎么好意思说你是一个合格的开发呢&#xff1f; 除了开发&#xff0c;工作或者生活当中&#xff0c;也存在着非常多的“异常程…

kill命令 和 kill函数

kill命令 kill命令是一个在Unix、Linux和类似系统中用于终止&#xff08;停止&#xff09;进程的命令。通过kill命令&#xff0c;可以向指定的进程发送一个信号&#xff0c;从而影响进程的运行状态。默认情况下&#xff0c;kill命令发送一个TERM信号&#xff0c;让进程优雅地退…

Linux 之 kill 命令

一. kill命令简介 在Linux系统中&#xff0c;kill命令用于向运行中的进程发送信号&#xff0c;默认发送的信号是终止信号&#xff0c;会请求进程退出。kill&#xff08;杀&#xff09;可能会引起误解&#xff0c;实际上发送的信号可能与杀死进程无关。 我们最常使用到的kill命令…

TR069 ACS

TR-069是由DSL论坛&#xff08;www.dslforum.org&#xff09;所开发的技术规范之一&#xff0c;其全称为“CPE广域网管理协议”。它提供了对下一代网络中家庭网络设备进行管理配置的通用框架和协议&#xff0c;用于从网络侧对家庭网络中的网关、路由器、机顶盒等设备进行远程集…

tr069 Cpe ACS 模拟器

完美支持tr069报文调试,支持反向链接,0 /1/2/4/等事件,支持信令&#xff0c;支持流程组合,支持PNP,告警等 文件下有config.ini,修改相关配置即可使用 支持批量开站心跳等. 版本历史: 1.0 增加业务网管开站 增加初始网管开站 1.1 优化 1.2 支持CWMP-ID 1.3 增加位置绑定 1.3…

基于TR069协议管理平台(XACS)多场景解决方案之一《TR069测试平台》

TR069测试平台(XACS) 为CPE设备TR069协议开发优化的版本&#xff0c;支持TR069协议基本操作&#xff0c;并可跟踪报文交互&#xff0c;适用于协议功能测试 1. TR069基本操作 支持TR069规范基本操作&#xff0c;GetRPCMethods, GetParameterValues, SetParameterValues, GetPar…

TR069相关问题

TR069相关问题 1.出现tr069客户端不稳定现象2.上传配置不成功3.浏览器不兼容4.上报给网管的报文被拦截5.网管问题6.升级失败 1.出现tr069客户端不稳定现象 网管下发了某些设置命令或者设置wan连接重新启用了cwmpd进程 2.上传配置不成功 command_key值没有对应&#xff0c;赋…

TR069协议向导——一个帮助你了解TR069协议的简明教程(一)【转】

&#xff08;转自&#xff1a;https://blog.csdn.net/dreamcode/article/details/3864715&#xff09; 1.为什么需要TR069 随着VoIP、IPTV等越来越多IP终端设备的普及&#xff08;尤其在家庭中的普及&#xff09;&#xff0c;大量设备的配置和维护变得越来越困难&#xff0…

使用电信 TR069 内网架设 WireGuard 隧道异地组网

❝ 本文转自 Steins;Gate&#xff0c;原文&#xff1a;https://www.kryii.com/89.html&#xff0c;版权归原作者所有。欢迎投稿&#xff0c;投稿请添加微信好友&#xff1a;cloud-native-yang TR069 内网是运营商用于下发光猫管理网络的内网&#xff0c;同一运营商同一省份的内…

博通Broadcom SDK源码学习与开发12终结篇——TR069网管协议

声明&#xff1a;原创作品&#xff0c;严禁用于商业目的。 本系列文章将全面剖析以Bcm33xxx芯片开发Cablemodem产品的SDK源码为例&#xff0c;从编译系统到各个功能模块进行分析与探讨。 文章目录 0.写在前篇1. TR069的Makefile和源码2. 配置参数2.1 CLI命令2.2 CM ConfigFile…

TR069协议与商业应用1——概述(带目录索引)

声明&#xff1a;原创作品&#xff0c;严禁用于商业目的。 如有任何技术问题&#xff0c;欢迎和我交流&#xff1a;19826269205&#xff08;微信同号&#xff09;。 学习链接 免费学习 文章目录 1. 概述1.1 引言1. 2 TR069协议规范1.3 Easycwmp介绍1.4 TR069协议服务端测试工具…

TR069协议与商业应用4——TR069服务器测试工具

声明&#xff1a;原创作品&#xff0c;严禁用于商业目的。 如有任何技术问题&#xff0c;欢迎和我交流&#xff1a;19826269205&#xff08;微信同号&#xff09;。 腾讯课堂链接 B站免费视频部分 文章目录 1. openACS2. VigorACS3. XACS3.1 概述3.2. 设备接入3.3 管理端登录…

TR069-STUN

该模块依据TR-111实现STUN Server功能&#xff0c;基站设备&#xff08;CPE&#xff09;作为STUN Client&#xff0c;向STUN Server发送BINDING-REQUEST&#xff0c;CPE通过BINDING-RESPONSE响应消息获取设备是否在NAT之后&#xff0c;以及NAT类型。 如果设备在NAT之后&#xf…