成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

MySQL kill不掉線程的原因

瀏覽:2日期:2023-10-03 14:45:39
背景

在日常的使用過程中,時不時會遇到個別,或者大量的連接堆積在 MySQL 中的現象,這時一般會考慮使用 kill 命令強制殺死這些長時間堆積起來的連接,盡快釋放連接數和數據庫服務器的 CPU 資源。

問題描述

在實際操作 kill 命令的時候,有時候會發現連接并沒有第一時間被 kill 掉,仍舊在 processlist 里面能看到,但是顯示的 Command 為 Killed,而不是常見的 Query 或者是 Execute 等。例如:

mysql> show processlist;+----+------+--------------------+--------+---------+------+--------------+---------------------------------+| Id | User | Host | db | Command | Time | State| Info |+----+------+--------------------+--------+---------+------+--------------+---------------------------------+| 31 | root | 192.168.1.10:50410 | sbtest | Query | 0 | starting | show processlist|| 32 | root | 192.168.1.10:50412 | sbtest | Query | 62 | User sleep | select sleep(3600) from sbtest1 || 35 | root | 192.168.1.10:51252 | sbtest | Killed | 47 | Sending data | select sleep(100) from sbtest1 || 36 | root | 192.168.1.10:51304 | sbtest | Query | 20 | Sending data | select sleep(3600) from sbtest1 |+----+------+--------------------+--------+---------+------+--------------+---------------------------------+原因分析

遇事不決先翻官方文檔,這里摘取部分官方文檔的內容:

When you use KILL, a thread-specific kill flag is set for the thread. In most cases, it might take some time for the thread to die because the kill flag is checked only at specific intervals:During SELECT operations, for ORDER BY and GROUP BY loops, the flag is checked after reading a block of rows. If the kill flag is set, the statement is aborted. ALTER TABLE operations that make a table copy check the kill flag periodically for each few copied rows read from the original table. If the kill flag was set, the statement is aborted and the temporary table is deleted. The KILL statement returns without waiting for confirmation, but the kill flag check aborts the operation within a reasonably small amount of time. Aborting the operation to perform any necessary cleanup also takes some time. During UPDATE or DELETE operations, the kill flag is checked after each block read and after each updated or deleted row. If the kill flag is set, the statement is aborted. If you are not using transactions, the changes are not rolled back. GET_LOCK() aborts and returns NULL. If the thread is in the table lock handler (state: Locked), the table lock is quickly aborted. If the thread is waiting for free disk space in a write call, the write is aborted with a “disk full” error message.

官方文檔第一段就很明確的說清楚了 kill 的作用機制:會給連接的線程設置一個線程級別的 kill 標記,等到下一次“標記檢測”的時候才會生效。這也意味著如果下一次“標記檢測”遲遲沒有發生,那么就有可能會出現問題描述中的現象。

官方文檔中列舉了不少的場景,這里根據官方的描述列舉幾個比較常見的問題場景:

select 語句中進行 order by,group by 的時候,如果服務器 CPU 資源比較緊張,那么讀取/獲取一批數據的時間會變長,從而影響下一次“標記檢測”的時間。 對大量數據進行 DML 操作的時候,kill 這一類 SQL 語句會觸發事務回滾(InnoDB引擎),雖然語句被 kill 掉了,但是回滾操作也會非常久。 kill alter 操作時,如果服務器的負載比較高,那么操作一批數據的時間會變長,從而影響下一次“標記檢測”的時間。 其實參考 kill 的作用機制,做一個歸納性的描述的話,那么:任何阻塞/減慢 SQL 語句正常執行的行為,都會導致下一次“標記檢測”推遲、無法發生,最終都會導致 kill 操作的失敗。 模擬一下

這里借用一個參數innodb_thread_concurrency來模擬阻塞 SQL 語句正常執行的場景:

Defines the maximum number of threads permitted inside of InnoDB. A value of 0 (the default) is interpreted as infinite concurrency (no limit). This variable is intended for performance tuning on high concurrency systems.

參照官方文檔的描述,這個參數設置得比較低的時候,超過數量限制的 InnoDB 查詢會被阻塞。因此在本次模擬中,這個參數被設置了一個非常低的值。

mysql> show variables like ’%innodb_thread_concurrency%’;+---------------------------+-------+| Variable_name | Value |+---------------------------+-------+| innodb_thread_concurrency | 1 |+---------------------------+-------+1 row in set (0.00 sec)

然后開兩個數據庫連接(Session 1 和 Session 2),分別執行select sleep(3600) from sbtest.sbtest1語句,然后在第三個連接上 kill 掉 Session 2 的查詢:

Session 1:mysql> select sleep(3600) from sbtest.sbtest1;Session 2:mysql> select sleep(3600) from sbtest.sbtest1;ERROR 2013 (HY000): Lost connection to MySQL server during querymysql>Session 3:mysql> show processlist;+----+------+--------------------+------+---------+------+--------------+----------------------------------------+| Id | User | Host | db | Command | Time | State| Info |+----+------+--------------------+------+---------+------+--------------+----------------------------------------+| 44 | root | 172.16.64.10:39290 | NULL | Query | 17 | User sleep | select sleep(3600) from sbtest.sbtest1 || 45 | root | 172.16.64.10:39292 | NULL | Query | 0 | starting | show processlist || 46 | root | 172.16.64.10:39294 | NULL | Query | 5 | Sending data | select sleep(3600) from sbtest.sbtest1 |+----+------+--------------------+------+---------+------+--------------+----------------------------------------+3 rows in set (0.00 sec)mysql> kill 46;Query OK, 0 rows affected (0.00 sec)mysql> show processlist;+----+------+--------------------+------+---------+------+--------------+----------------------------------------+| Id | User | Host | db | Command | Time | State| Info |+----+------+--------------------+------+---------+------+--------------+----------------------------------------+| 44 | root | 172.16.64.10:39290 | NULL | Query | 26 | User sleep | select sleep(3600) from sbtest.sbtest1 || 45 | root | 172.16.64.10:39292 | NULL | Query | 0 | starting | show processlist || 46 | root | 172.16.64.10:39294 | NULL | Killed | 14 | Sending data | select sleep(3600) from sbtest.sbtest1 |+----+------+--------------------+------+---------+------+--------------+----------------------------------------+3 rows in set (0.00 sec)mysql>

可以看到,kill 命令執行之后,Session 2 的連接馬上就斷開了,但是 Session 2 發起的查詢仍舊殘留在 MySQL 中。當然,如果是因為innodb_thread_concurrency這個參數導致了類似的問題的話,直接使用set global的命令調高上限,或者直接設置為 0 就可以解決,這個參數的變更是實時對所有連接生效的。

總結一下

MySQL 的 kill 操作并不是想象中的直接強行終止數據庫連接,只是發送了一個終止的信號,如果 SQL 自身的執行效率過慢,或者受到其他的因素影響(服務器負載高,觸發大量數據回滾)的話,那么這個 kill 的操作很有可能并不能及時終止這些問題查詢,反而可能會因為程序側連接被斷開之后觸發重連,產生更多的低效查詢,進一步拖垮數據庫。

以上就是MySQL kill不掉線程的原因的詳細內容,更多關于MySQL kill線程的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
色综合久久66| 国产精品久久福利| 国语精品中文字幕| 国产精品久久久久一区二区三区共| 国产日韩欧美一区| 欧美日韩亚洲丝袜制服| 国产欧美日本在线| 亚洲欧美日韩在线| 欧美视频三区在线播放| 国产福利一区二区三区在线视频| 国产精品午夜免费| 成人中文字幕在线| 亚洲三级电影全部在线观看高清| 欧美日韩在线亚洲一区蜜芽| 激情亚洲成人| 精品电影一区| 国产真实乱子伦精品视频| 亚洲欧美一区二区视频| 欧美日韩一区三区四区| 亚洲视频免费| 国产精品乡下勾搭老头1| 亚洲精品免费一二三区| 精品国产乱码久久久久久1区2区| 91国产视频在线观看| 欧美日韩亚洲一区二区三区四区| 国产一区高清在线| 亚洲成人动漫在线观看| 欧美影视一区在线| 亚洲第一黄网| 99久久久国产精品免费蜜臀| 久久精品国产免费| 亚洲一级不卡视频| 国产欧美日韩在线视频| 欧美一区中文字幕| 免费日韩视频| 精品91在线| www.日韩在线| 久久久91精品国产一区二区精品| 欧美日韩一卡二卡三卡| 一本色道久久加勒比精品| 亚洲一区图片| 国产欧美日韩一区二区三区| 亚洲欧美在线网| 99久久婷婷国产综合精品电影| 国产成人精品一区二区三区四区 | 亚洲综合色噜噜狠狠| 久久久精品2019中文字幕之3| 欧美日韩你懂的| 美女亚洲精品| 亚洲国产精品日韩| 99久久免费视频.com| 99精品国产高清一区二区| 99re这里只有精品视频首页| 日韩中文字幕麻豆| 亚洲免费视频中文字幕| 国产婷婷色一区二区三区四区| 欧美老年两性高潮| 在线免费精品视频| 亚洲男人影院| 亚洲作爱视频| 黄色国产精品一区二区三区| 成人18精品视频| 国模无码大尺度一区二区三区| 日韩激情中文字幕| 一区二区欧美国产| 中文字幕在线不卡视频| 国产精品传媒入口麻豆| 精品福利一二区| 欧美一级精品在线| 91精品国产欧美一区二区| 欧美日韩一区久久| 欧美三级日韩在线| 欧美性videosxxxxx| 日本高清视频一区二区| 久久激情中文| 裸体一区二区| 性色一区二区三区| 午夜在线视频一区二区区别| 亚洲综合另类| 国产成人免费在线| 另类小说图片综合网| 亚洲国产wwwccc36天堂| 国产精品大尺度| 国产精品免费视频网站| 国产欧美一区二区三区鸳鸯浴| 久久亚洲欧美国产精品乐播| 欧美大度的电影原声| 日韩亚洲欧美一区二区三区| 欧美日韩高清影院| 欧美日韩成人一区二区| 欧美日韩三级视频| 欧美美女激情18p| 在线不卡一区二区| 欧美伊人久久久久久午夜久久久久| 美日韩在线观看| 久久激情综合| 久久精品人人| 久久九九精品| 一本到不卡免费一区二区| 欧美日韩和欧美的一区二区| 久久人人九九| 亚洲福利精品| 欧美日韩一区二区三区在线观看免 | 亚洲视频一区在线| 久久综合久色欧美综合狠狠| 欧美日韩综合在线| 在线精品视频免费观看| 色诱视频网站一区| 美日韩精品视频| 亚洲影视在线| 色视频一区二区| 亚洲欧美日韩在线观看a三区| 一区二区三区国产在线| 亚洲视频观看| 在线观看的日韩av| 亚洲视频欧美在线| 久久精品国产澳门| 亚洲乱码中文字幕| 亚洲精品欧美专区| 精品久久久久99| 精品国产91久久久久久久妲己| 久久精品夜色噜噜亚洲a∨| 国产精品久久久久久久久免费桃花| 亚洲欧美日韩在线不卡| 偷窥少妇高潮呻吟av久久免费| 久久精品久久综合| 国产91露脸合集magnet| 女主播福利一区| 夜夜嗨网站十八久久| 色综合久久久网| 在线成人小视频| 国产日韩欧美在线一区| 亚洲精品国产无天堂网2021| 日韩电影免费在线| 国产成人自拍网| 97se亚洲国产综合自在线 | 亚洲色图欧美在线| 亚洲v日本v欧美v久久精品| 九色综合国产一区二区三区| 成人app在线| 亚洲福利久久| 在线观看www91| 欧美精品一区二区蜜臀亚洲| 中文字幕一区在线观看| 亚洲国产美国国产综合一区二区| 老色鬼精品视频在线观看播放| 成人av在线网站| 亚洲国产午夜| 老司机午夜精品视频在线观看| 欧美日韩综合一区| 精品国产一区久久| 夜夜精品视频一区二区| 国产在线精品一区二区夜色 | 一本色道88久久加勒比精品| 欧洲精品在线观看| 久久久99久久精品欧美| 亚洲小说春色综合另类电影| 国产在线精品一区二区夜色| 欧美极品一区| 久久久久在线| 欧美成人性福生活免费看| 亚洲欧洲色图综合| 蜜臀av在线播放一区二区三区 | 国产欧美日韩中文久久| 亚洲国产中文字幕在线视频综合| 韩国av一区二区三区在线观看| 欧美国内亚洲| 色哟哟国产精品免费观看| 久久影院午夜片一区| 亚洲成av人片在www色猫咪| 国产麻豆一精品一av一免费 | 色偷偷成人一区二区三区91| 精品少妇一区二区三区| 一级做a爱片久久| 国产精品18久久久| 亚洲美女色禁图| 911精品国产一区二区在线| 亚洲色图制服诱惑| 韩日欧美一区二区三区| 韩日精品在线| 欧美日韩精品综合在线| 国产精品成人在线观看| 国产在线精品一区二区不卡了| 国内精品一区二区| 欧美色中文字幕| 亚洲国产精品高清| 精彩视频一区二区| 亚洲激情亚洲| 日韩一二三区不卡| 一区二区三区丝袜| 成人av在线播放网址| 久久精品麻豆| 国产欧美一区二区精品婷婷 | 色www精品视频在线观看| 国产亚洲精品免费| 久久精品国产亚洲aⅴ| 国产综合亚洲精品一区二| 欧美剧情片在线观看| 亚洲区小说区图片区qvod| 成人综合在线网站|