MySQL找出鎖等待

1.服務器級別的鎖等待
可以通過show processlist看到等待鎖的線程id,但是無法知道究竟哪個線程持有鎖
可以通過mysqladmin debug
相關等待鎖的線程以及誰持有鎖可以在錯誤日志中找到
2.存儲引擎層的鎖等待則比較麻煩,以下是innodb存儲引擎中鎖等待以及哪個線程持有鎖的查找sql
SELECT r.trx_id AS waiting_trx_id, r.trx_mysql_thread_id AS waiting_thread, TIMESTAMPDIFF(SECOND, r.trx_wait_started, CURRENT_TIMESTAMP) AS wait_time, r.trx_query AS waiting_query, l.lock_table AS waiting_table_lock, b.trx_id AS blocking_trx_id, b.trx_mysql_thread_id AS blocking_thread, SUBSTRING(p.host,1,INSTR(p.host, ':') -1 ) AS blocking_host, SUBSTRING(p.host, INSTR(p.host, ':') +1 ) AS block_port, IF(p.command="Sleep",p.time,0) AS idle_in_trx, b.trx_query AS blcoking_query from information_schema.innodb_lock_waits AS w INNER JOIN information_schema.innodb_trx AS b ON b.trx_id=w.blocking_trx_id INNER JOIN information_schema.innodb_trx AS r ON r.trx_id = w.requesting_trx_id INNER JOIN information_schema.innodb_locks AS l ON w.requested_lock_id = l.lock_id LEFT JOIN information_schema.processlist AS p ON p.id = b.trx_mysql_thread_id ORDER BY wait_time DESC\G
3.如果因為線程在一個事務中空閑而正在遭受大量的鎖操作,下面查詢顯示存儲引擎層有多少查詢被哪些線程阻塞。
SELECT CONCAT('thread ', b.trx_mysql_thread_id, ' from ',p.host) AS who_blocks, IF (p.command = "Sleep",p.time, 0) AS idle_in_trx, MAX(TIMESTAMPDIFF(SECOND,r.trx_wait_started,NOW())) AS max_wait_time, COUNT(*) AS num_waiters FROM information_schema.innodb_lock_waits as w inner join information_schema.innodb_trx as b on b.trx_id = w.blocking_trx_id inner join information_schema.innodb_trx as r on r.trx_id = w.requesting_trx_id left join information_schema.processlist as p on p.id = b.trx_mysql_thread_id  group by who_blocks order by num_waiters desc\G

參考資料

<<高性能mysql第三版>>

轉載于:https://www.cnblogs.com/gomysql/p/3608466.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258830.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258830.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258830.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C++給函數傳數組參數C++給函數傳數組參數

C給函數傳數組參數 在C中&#xff0c;如果要給一個函數傳入一個數組&#xff0c;一般都是傳入兩個參數一個數組指針和一個數組大小 例&#xff1a; void print_1 (int n, int *datas ) { for (int i 0; i < n; i) { std::cout << datas[i] <<…

clover引導mbr安裝黑蘋果_安裝黑蘋果記錄(一)

從來沒有接觸過macOS(蘋果系統)&#xff0c;孩子說他用的那臺電腦linux不能安裝一些軟件&#xff0c;問我能不能安裝黑蘋果&#xff0c;一些軟件只有win和mac的客戶端&#xff0c;卻沒有linux版本。他知道我不會給他安裝Windows&#xff0c;一個是怕他玩游戲&#xff0c;另外一…

人口變動的經濟分析

佳木斯市人口變動的經濟分析上 人口生產和物質生產&#xff0c;是有史以來人類社會同時存在和同步發展的兩種生產&#xff0c;一切經濟變動都與人口變動有直接或間接的關系&#xff0c;而一切人口變動又可以從經濟變動中找到原因。為此&#xff0c;本文試根據我國、我省和我市第…

【javascript】操作符:一元操作符

一、一元操作符 <script>// var num1,num2,num3; num11;num22; alert(num1num2);//4 在前 alert(num1num2);//4 num11; alert(num1--num2);//3 num1NaN; alert(num1num2);//NaN num1true; alert(num1num2);//3 true轉化成了1 num1fal…

doxygen問題集錦

使用doxygen排版數學公式出錯的解決方法 參考&#xff1a;http://blog.csdn.net/huangbo10/article/details/46801949 問題 今天玩了一下doxygen&#xff0c;碰到一個問題 ! Undefined control sequence. l.77 $ y_{\mbox{test}} \mathbb{E}[y_{\mbox{train}}] x $ ? !…

ubuntu中make頭文件找不到_和平精英:游戲中找不到人怎么辦?這些技巧幫你練出“火眼金睛”...

大家好&#xff0c;歡迎來到《刺激實戰教室》&#xff0c;我是你們的老朋友刺激哥。俗話說&#xff0c;電子競技不需要視力&#xff0c;而這句話也是《和平精英》的一個“痛點”。在《和平精英》這款游戲中&#xff0c;更是如此。在很多時候&#xff0c;敵人就藏在我們的附近&a…

[CDA數據分析師學習之路] 【CDA就業班獨家發布】學習之路

http://bbs.pinggu.org/thread-4677737-1-1.html轉載于:https://blog.51cto.com/xbh1314/1923452

jdk8永久代從方法區移除的驗證

/*** 測試使用jdk8中是否仍然可以使用永久代* jvm options * -Xms20m -Xmx20m -Xmn10m -XX:PermSize10m -XX:MaxPermSize10m -XX:PrintGCDetails* * 結果運行提示&#xff1a;* Java HotSpot(TM) Client VM warning: ignoring option PermSize10m; support was removed in 8.0*…

eureka配置_F版本SpringCloud 5—Eureka集群和自我保護機制

源碼地址&#xff1a;https://gitee.com/bingqilinpeishenme/Java-Tutorials前言上篇文章中&#xff0c;通過代碼搭建了Eureka注冊中心和客戶端&#xff0c;是Eureka的簡單應用&#xff0c;在本文中將會講解更多關于Eureka服務端的應用以及原理。Eureka 自我保護機制進入自我保…

windows共享內存

在windows編程中避免不了使用共享內存&#xff0c;因為他是進程間通信、文件讀取最簡單的方式&#xff0c;有書上還說其他進程間通訊機制如管、油槽、WM_COPYDATA底層也是用的共享內存機制。關于使用方法還是請參考MSDN。 最近聽說使用共享內存不安全&#xff0c;可能會被其他進…

Chrome指令/追蹤Http請求相關

2019獨角獸企業重金招聘Python工程師標準>>> Chrome HTTP抓包&#xff0c;在地址欄輸入 chrome://net-internals/#requests轉載于:https://my.oschina.net/u/2292141/blog/895603

離散卷積與自相關

本文章轉載自&#xff1a;http://www.cnblogs.com/einyboy/archive/2012/12/30/2839633.html 一、 定義 離散信號f(n),g(n)的定義如下&#xff1a; N-----為信號f(n)的長度 s(n)----為卷積結果序列,長度為len(f(n))len(g(n))-1 例&#xff1a; f(n) [1 2 3]; g(n) [2 3 1]; …

PHP文件操作類

<?php /*************************************************************************************** 文件名&#xff1a;File.cls.php 文件簡介&#xff1a;類clsFile的定義&#xff0c;對文件操作的封裝 版本&#xff1a;2.0 最后修改日期&#xff1a;2011-8-23 *******…

excel打開后灰色不顯示內容_Excel二維表轉換,一分鐘就夠

點擊藍字關注我們44個Excel 使用技巧基本方法作為職場人&#xff0c;加班累如狗。如何更輕松的工作并獲得喜人的報酬便是咱們職場人一直追求的“生活哲理”&#xff0c;說到Excel,對于辦公室群體而言實在是太常見不過了&#xff0c;不管做什么&#xff0c;咱們都會跟它打交道&a…

利用PHP SOAP實現web service

一 什么是SOAP&#xff1f;可以做什么&#xff1f; SOAP 指簡單對象訪問協議&#xff0c;它是一種基于XML的消息通訊格式&#xff0c;用于網絡上&#xff0c;不同平臺&#xff0c;不同語言的應用程序間的通訊。可自定義&#xff0c;易于擴展。一條 SOAP 消息就是一個普通的 XML…

UVA350-水題

UVA350-水題 #include<iostream>using namespace std;int main() {int c 0;int Z, L, I, M;while (cin >> Z >> I >> M >> L){c;if(Z L && L I && I M && M 0){return 0;}int i 1;int K, P;I I % M;Z Z % M;K …

卷積的循環矩陣求解方法

通常我們求解一維卷積或者二維卷積都是采用模板平移的方法&#xff0c;今天我們介紹一種新的求解方法&#xff0c;可以一次性求出所有的結果。 一維卷積 卷積定義 對于兩個長度分別為m和n的序列x(i)和g(i)有&#xff0c; h(i)x(i)?g(i)∑jx(j)g(i?j)h(i)=x(i)*g(i)=\sum_…

Windows 10 開發日記(五)-- 當Binding遇到異步 -- 解決方案

前文再續&#xff0c;上一章提出了問題&#xff0c;本章提出了三種解決方案&#xff1a; 解決方案一&#xff1a;手動進行異步轉換,核心思想:將binding做的事情放入CodeBehind FilterItemControl.XAML: <Grid><Image x:Name"FilterImage" Stretch"Unif…

fseek

int fseek( FILE *stream, long offset, int origin );第一個參數stream為文件指針第二個參數offset為偏移量&#xff0c;正數表示正向偏移&#xff0c;負數表示負向偏移第三個參數origin設定從文件的哪里開始偏移,可能取值為&#xff1a;SEEK_CUR、 SEEK_END 或 SEEK_SETSEEK_…

static_cast, dynamic_cast, const_cast探討【轉】

首先回顧一下C類型轉換&#xff1a; C類型轉換分為&#xff1a;隱式類型轉換和顯式類型轉換 第1部分. 隱式類型轉換又稱為“標準轉換”&#xff0c;包括以下幾種情況&#xff1a;1) 算術轉換(Arithmetic conversion) : 在混合類型的算術表達式中, 最寬的數據類型成為目標轉換類…