日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

MySQL kill不掉線程的原因

瀏覽:33日期: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 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产亚洲毛片在线| 夜久久久久久| 亚洲精品系列| 久久中文字幕av一区二区不卡| 精品伊人久久| 国产精品一区二区三区美女| 久久国产精品免费精品3p| 91精品尤物| 最新亚洲国产| 天堂精品久久久久| 日韩黄色在线观看| 久久激五月天综合精品| 国产精品视频一区二区三区| 久久不见久久见免费视频7| 国产福利一区二区三区在线播放| 国产精品调教视频| 欧美日本一区| 欧美极品中文字幕| 国产一区二区精品久| 日韩欧美国产精品综合嫩v| 日韩欧美三级| 亚洲自啪免费| 日韩动漫一区| 久久亚洲道色| 亚洲91精品| 免费人成在线不卡| 日本精品另类| 精品久久福利| 婷婷激情久久| 亚州欧美在线| 麻豆中文一区二区| 蜜臀久久精品| 亚洲精品网址| 亚洲精品日韩久久| 久久不见久久见免费视频7 | 欧美黄页在线免费观看| 国产欧美一区| 亚洲精品日韩久久| 久久久噜噜噜| 石原莉奈在线亚洲三区| 婷婷亚洲成人| 精品久久久中文字幕| 今天的高清视频免费播放成人| 亚洲无线观看| 国产一区二区三区不卡视频网站 | 婷婷亚洲五月色综合| 综合五月婷婷| 国产成人精品一区二区三区视频| 高潮一区二区| 日韩影院免费视频| 美女视频免费精品| 国内激情久久| 国产欧美日韩在线一区二区| 亚洲国产福利| 日精品一区二区三区| 日韩1区在线| 男人的天堂亚洲一区| 精品国产一区二区三区性色av| 九九久久婷婷| 国产精品手机在线播放| 狠狠干综合网| 精品一区二区三区免费看 | 亚洲免费中文| 精品一区二区三区亚洲| 日韩精品一级中文字幕精品视频免费观看 | 国产精品igao视频网网址不卡日韩| 超级白嫩亚洲国产第一| 日韩中文字幕1| 亚洲精品88| 色狠狠一区二区三区| 日韩在线欧美| 久久激五月天综合精品| 亚洲精品a级片| 色婷婷色综合| 日韩在线观看中文字幕| 久久影视一区| 国产日韩视频在线| 影音先锋久久| 国产美女高潮在线观看| 日韩激情精品| 欧美日韩国产综合网| 国产精品videossex| 伊人久久婷婷| 色婷婷精品视频| 美女视频一区在线观看| 一区二区不卡| 欧美jjzz| 97视频热人人精品免费| 久久丁香四色| 亚洲欧洲av| 一本一道久久a久久精品蜜桃| 免费日韩成人| 日韩高清一区| 日韩中文欧美在线| 悠悠资源网久久精品| 高清在线一区| 麻豆久久一区| 国产探花一区二区| 免费不卡在线视频| 欧美网站在线| 韩国精品主播一区二区在线观看| 国产精品美女午夜爽爽| 日韩欧美中文字幕一区二区三区| 日韩视频二区| 日本国产精品| 亚洲欧洲高清| 国产一区二区三区日韩精品 | 国产+成+人+亚洲欧洲在线| 欧美一区影院| 鲁大师成人一区二区三区 | 91精品韩国| 日韩av自拍| 欧美日韩国产观看视频| 久久精品国产网站| 欧美激情福利| 久久69成人| 国产一区二区三区天码| 国产极品嫩模在线观看91精品| 欧美日韩伊人| 日韩高清成人在线| 一区二区精品| 亚洲欧洲免费| 男人的天堂久久精品| 久热精品在线| 热久久国产精品| 蜜臀久久久99精品久久久久久| 久久av在线| 亚洲深夜av| 国产精品外国| 蜜桃视频在线观看一区| 亚洲欧美一级| 国产精品主播| 国产精久久久| 国产成人免费视频网站视频社区| 精品网站999| 国产一区调教| 日韩精品91| 欧美日韩中文一区二区| 亚洲免费精品| 日韩在线成人| 免费日韩一区二区三区| www.九色在线| 久久中文字幕二区| 久久午夜视频| 天堂av一区| 久久成人高清| 久久久国产精品一区二区中文| 欧美影院三区| 亚洲一区二区三区中文字幕在线观看| 日韩精品中文字幕一区二区| 欧美日韩一区自拍| 国产成人免费| 一区二区自拍| 日韩av不卡一区二区| 欧美黄色一区二区| 91精品亚洲| 一区二区国产在线| 久久精品国产在热久久| 欧美肉体xxxx裸体137大胆| 最新国产精品视频| 精品一区二区三区四区五区| 久久久久.com| 一区二区三区四区日韩| 国产精品15p| 国产一区二区中文| 亚洲专区视频| 欧美国产日韩电影| 久久影视一区| 日韩精品91亚洲二区在线观看| 麻豆一区二区三| 亚洲高清成人| 亚洲麻豆一区| 麻豆精品少妇| 伊人久久婷婷| 国产精品欧美在线观看| 欧产日产国产精品视频| 日韩在线一二三区| 麻豆国产精品视频| 性欧美69xoxoxoxo| 日本欧美一区二区| 亚洲精品.com| 亚洲精品婷婷| 免费福利视频一区二区三区| 亚洲欧美在线专区| 亚洲精品在线影院| 日本午夜精品一区二区三区电影 | 欧美综合另类| 91精品啪在线观看国产爱臀| 日韩久久视频| 91国内精品| 亚洲特色特黄| 国产日产精品_国产精品毛片| 99精品视频在线| 国产午夜久久av| 久久大逼视频| 最近高清中文在线字幕在线观看1| 亚洲精品极品| 1024精品一区二区三区| 国产精品videossex久久发布 | 国产a亚洲精品|