成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_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国内精品久久久久久久
欧美日韩成人激情| 欧美 日韩 国产精品免费观看| www.亚洲国产| 91精品国产乱码久久蜜臀| 日本欧美一区二区三区| 久久久夜夜夜| 日产欧产美韩系列久久99| 免费日韩av片| 亚洲久本草在线中文字幕| 亚洲午夜av| 中文字幕亚洲区| 亚洲激情网站| 综合精品久久久| 亚洲精品在线二区| 一区二区三区资源| 亚洲一区在线免费| 日韩精品电影在线观看| 老司机午夜精品视频| 日本不卡视频在线观看| 在线观看国产精品网站| 寂寞少妇一区二区三区| 欧美一区二区三区喷汁尤物| 国产成人精品亚洲777人妖| 日韩欧美中文字幕一区| 成人污视频在线观看| 精品国产乱码久久久久久免费 | 国产精品第四页| 在线欧美不卡| 亚洲国产成人精品视频| 在线观看精品一区| 国产老妇另类xxxxx| 欧美tickle裸体挠脚心vk| 91在线国内视频| 国产精品久久久久久久久果冻传媒| 亚洲激情婷婷| 日韩不卡一二三区| 欧美一区二区在线免费播放| 99久久久免费精品国产一区二区| 中文字幕一区二区5566日韩| 亚洲综合不卡| 久久精品国产久精国产爱| 91精品一区二区三区在线观看| 成人动漫视频在线| 自拍偷自拍亚洲精品播放| 99亚洲视频| 青青草91视频| 日韩欧美一区二区久久婷婷| 欧美日韩爆操| 一区二区三区高清| 久久综合狠狠综合久久综青草| 国内成+人亚洲+欧美+综合在线| 日韩欧美激情在线| 好看不卡的中文字幕| 亚洲国产精品久久久久秋霞影院| 欧美午夜寂寞影院| 91在线丨porny丨国产| 伊人一区二区三区| 欧美日韩高清一区二区三区| 99re免费视频精品全部| 一区二区三区欧美在线观看| 欧美手机在线视频| 欧美激情1区2区| 亚洲午夜久久久久久久久电影网| 欧美精品自拍偷拍| 国产精品a久久久久| 婷婷成人综合网| 日韩一级欧美一级| 亚洲激情国产| 韩国视频一区二区| 国产精品视频一区二区三区不卡| 国产视频一区在线观看一区免费| 狠狠色狠狠色综合系列| 欧美国产日韩a欧美在线观看| 久久av最新网址| 成人不卡免费av| 亚洲一级在线观看| 欧美成人aa大片| 国产女优一区| 99re视频这里只有精品| 亚洲va欧美va人人爽午夜 | 婷婷一区二区三区| 久久久午夜精品| 久久岛国电影| 暴力调教一区二区三区| 亚洲大片免费看| 欧美mv日韩mv国产网站| 一区二区三区偷拍| 不卡在线观看av| 午夜精品久久久久久久99水蜜桃| 欧美r级在线观看| 亚洲一区二区高清视频| 国产成人免费9x9x人网站视频| 亚洲人成网站色在线观看| 欧美久久久久免费| 1000部精品久久久久久久久| 国产一区91精品张津瑜| 一区二区三区国产精品| 2020国产精品久久精品美国| 香蕉久久夜色| 欧美在线播放一区二区| 久久精品国产99| 亚洲人成伊人成综合网小说| 日韩一区二区免费在线电影| 西西人体一区二区| 欧美 日韩 国产精品免费观看| 日韩av电影天堂| 国产精品天天摸av网| 欧美美女直播网站| 国产日韩一区二区三区在线播放| 99riav久久精品riav| 美腿丝袜亚洲三区| 亚洲黄一区二区三区| 久久色.com| 色婷婷亚洲精品| 一区一区视频| 成人视屏免费看| 青青草伊人久久| 一区二区三区精密机械公司| 国产亚洲制服色| 91精品久久久久久蜜臀| 久久综合九色综合网站| 在线精品福利| 暖暖成人免费视频| 国产盗摄一区二区| 奇米一区二区三区| 亚洲午夜在线电影| 亚洲视频一区二区免费在线观看| 精品国产露脸精彩对白| 欧美日韩精品一区二区三区 | 精品国产乱码久久久久久久| 91福利国产成人精品照片| 亚洲日本激情| 欧美国产一区二区三区激情无套| 国产一区二区三区观看| 人禽交欧美网站| 亚洲国产成人av| 亚洲免费观看高清完整| 欧美激情一区二区| 久久亚洲免费视频| 欧美一区二区三区四区高清| 欧美在线free| 久久久久久久久久久久久久一区| 亚洲日本视频| 欧美三级在线| 色综合久久中文综合久久牛| 粉嫩嫩av羞羞动漫久久久| 国产在线精品免费| 美女视频第一区二区三区免费观看网站 | 亚洲欧美影院| 成人激情图片网| 国产精品69毛片高清亚洲| 日韩精品乱码av一区二区| 亚洲午夜私人影院| 亚洲午夜在线电影| 亚洲一区二区三区在线| 亚洲精品中文在线影院| 亚洲丝袜精品丝袜在线| 中文字幕欧美一区| 国产精品久久久久久久蜜臀| 中文字幕精品—区二区四季| 国产亚洲视频系列| 国产亚洲成av人在线观看导航 | 极品尤物av久久免费看| 久久99精品久久久久久国产越南 | 国产一区二区在线观看视频| 九九**精品视频免费播放| 久久av中文字幕片| 久久成人羞羞网站| 韩国视频一区二区| 国产精一品亚洲二区在线视频| 韩国三级在线一区| 国模套图日韩精品一区二区| 久久精品国产久精国产| 韩国午夜理伦三级不卡影院| 国产一区二区毛片| 国产高清一区日本| 成人免费高清视频在线观看| 不卡的av网站| 午夜国产欧美理论在线播放| 国产精品xxx在线观看www| 亚洲激情啪啪| 亚洲永久字幕| 欧洲一区在线电影| 3atv一区二区三区| 精品国产3级a| 亚洲国产高清在线| 自拍偷拍国产精品| 亚洲精品高清视频在线观看| 夜夜精品视频一区二区 | 黄色精品一区| 国产精品区一区| 91国产免费看| 欧美一区二区精品在线| 欧美精品一区二区三区很污很色的| 久久精品亚洲乱码伦伦中文| 国产精品看片你懂得| 亚洲一区二区在线视频| 男人操女人的视频在线观看欧美| 激情综合色综合久久综合| 北岛玲一区二区三区四区|