亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql查看鎖表及殺進(jìn)程問題

 更新時(shí)間:2023年07月27日 09:37:09   作者:a2589293499  
這篇文章主要介紹了mysql查看鎖表及殺進(jìn)程問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

mysql查看鎖表及殺進(jìn)程

查看進(jìn)程

登錄mysqlmysql -uroot -ppassword查看進(jìn)程mysql> show processlist;

各字段的含義

  • 1.id 該進(jìn)程的標(biāo)識(shí);
  • 2.user 顯示當(dāng)前用戶
  • 3.host 顯示來源IP和端口
  • 4.db 顯示當(dāng)前連接的數(shù)據(jù)庫
  • 5.command 顯示當(dāng)前連接的執(zhí)行的命令,休眠 sleep ,查詢 query ,連接 connect 
  • 6.time 此這個(gè)狀態(tài)持續(xù)的時(shí)間,單位是秒
  • 7.state列 顯示使用當(dāng)前連接的sql語句的狀態(tài),很重要的列,詳見下面state列的含義
  • 8.info 顯示sql語句,長(zhǎng)sql可能顯示不全 

state列的含義

  • 1.analyzing 比如進(jìn)行analyze table時(shí) 
  • 2.checking table 線程正在執(zhí)行表檢查操作 
  • 3.cleaning up 正準(zhǔn)備釋放內(nèi)存 
  • 4.closing tables 應(yīng)該是一個(gè)快速的操作,如果不是這樣的話,則應(yīng)該檢查硬盤空間是否已滿或者磁盤io是否達(dá)到瓶頸 
  • 5.copy to tmp table 線程正在處理一個(gè)alter table語句 
  • 6.copying to tmp table 線程將數(shù)據(jù)寫入內(nèi)存中的臨時(shí)表 
  • 7.copying to tmp table on disk 線程正在將數(shù)據(jù)寫入磁盤中的臨時(shí)表。與tmp_table_size參數(shù)有關(guān)系 
  • 8.creating sort index 線程正在使用內(nèi)部臨時(shí)表處理一個(gè)select操作 
  • 9.fulltext initialization  服務(wù)器正準(zhǔn)備進(jìn)行自然語言全文索引 
  • 10.sending data 線程正在讀取和處理一條select語句的行,并且將數(shù)據(jù)發(fā)送至客戶端,在此期間會(huì)執(zhí)行大量的磁盤訪問 
  • 11.sorting index 線程正在對(duì)索引頁進(jìn)行排序 
  • 12.updating 線程尋找更新匹配的行進(jìn)行更新 
  • 13.waiting for lock_type lock 等待各個(gè)種類的表鎖 

當(dāng)state列為waiting for lock_type lock時(shí),表示某個(gè)SQL正在query導(dǎo)致別的SQL等待鎖,需要根據(jù)id殺進(jìn)程。

殺進(jìn)程

1.殺單個(gè)進(jìn)程

mysql>?kill 127402;

2.殺多個(gè)進(jìn)程,組裝kill語句

select concat('kill ',id,';') from information_schema.processlist where user='root' and state='waiting for lock_type lock';執(zhí)行組裝后的kill語句

其他有用命令

查看被鎖的表

mysql>?show open tables where in_use > 0;

查看當(dāng)前的事務(wù)

mysql>?select * from information_schema.innodb_trx;

查看被鎖的事務(wù)

mysql>?select * from information_schema.innodb_locks;

查看等鎖的事務(wù)

mysql>?select * from information_schema.innodb_lock_waits;

mysql鎖表原因及解決

問題如圖

在這里插入圖片描述

鎖表發(fā)生原因

鎖表發(fā)生在 insert、update、delete中;

鎖表的原理是數(shù)據(jù)庫使用獨(dú)占式鎖機(jī)制,當(dāng)執(zhí)行上面的語句時(shí),對(duì)表進(jìn)行鎖住,直到發(fā)生commit或者rollback或者退出數(shù)據(jù)庫用戶;

鎖表的原因:

  • A程序執(zhí)行了對(duì)table_1的insert、update、delete,并還未commit時(shí),B程序也對(duì)table_1進(jìn)行insert、update、delete`時(shí)會(huì)發(fā)生資源正忙的異常,也就是鎖表;
  • 鎖表常發(fā)生與并發(fā)而不是并行(并行時(shí),一個(gè)線程操作數(shù)據(jù)庫時(shí),另一個(gè)線程是能操作數(shù)據(jù)庫的,cpu和i/o分配原則)
  • 鎖表也發(fā)生在事務(wù)嵌套,外層事務(wù)對(duì)table_1進(jìn)行了insert、update、delete,內(nèi)層事務(wù)(PROPAGATION_REQUIRES_NEW)也對(duì)table_1進(jìn)行了insert、update、delete,內(nèi)層事務(wù)commit的時(shí)需要等待外層事務(wù)先commit釋放資源(但是是不可能的),最終導(dǎo)致死鎖(本次問題就是事務(wù)嵌套導(dǎo)致)。多查幾次SELECT * FROM information_schema.innodb_trx ;如果鎖跟著業(yè)務(wù)結(jié)束(connect超時(shí))鎖沒了,那么基本上可以確定是業(yè)務(wù)代碼導(dǎo)致,需要分析業(yè)務(wù)代碼。

mysql鎖表解決

-- 找到超時(shí)的表,查詢超時(shí)的SQL
SELECT * FROM information_schema.innodb_trx ;
-- 查看當(dāng)前被使用的表,查詢是否有鎖表
-- SHOW OPEN TABLES:列舉在表緩存中當(dāng)前被打開的非TEMPORARY表。
-- In_use:表當(dāng)前被查詢使用的次數(shù)。如果該數(shù)為零,則表是打開的,但是當(dāng)前沒有被使用。
show OPEN TABLES where In_use > 0;
-- 查詢?nèi)值却聞?wù)鎖超時(shí)時(shí)間
SHOW GLOBAL VARIABLES LIKE 'innodb_lock_wait_timeout';
-- 設(shè)置全局等待事務(wù)鎖超時(shí)時(shí)間
SET  GLOBAL innodb_lock_wait_timeout=100;
-- 查詢當(dāng)前會(huì)話等待事務(wù)鎖超時(shí)時(shí)間
SHOW VARIABLES LIKE 'innodb_lock_wait_timeout';
-- 查看進(jìn)程id,然后用kill id殺掉進(jìn)程
show processlist;
SELECT * FROM information_schema.PROCESSLIST;
-- 查詢正在執(zhí)行的進(jìn)程
SELECT * FROM information_schema.PROCESSLIST where length(info) >0 ;
-- 查看被鎖住的
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
-- 等待鎖定
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
-- innodb_locks表在8.0.13版本中由performance_schema.data_locks表所代替,innodb_lock_waits表則由performance_schema.data_lock_waits表代替
-- 殺掉鎖表進(jìn)程
kill 5601

事務(wù)嵌套引起的死鎖

這時(shí)候就不能簡(jiǎn)單的kill掉進(jìn)程了,需要review代碼,找出問題代碼

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • win32 mysql 5.7.27 安裝配置方法圖文教程

    win32 mysql 5.7.27 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了win32 mysql 5.7.27 安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 揭秘SQL優(yōu)化技巧 改善數(shù)據(jù)庫性能

    揭秘SQL優(yōu)化技巧 改善數(shù)據(jù)庫性能

    這篇文章是以 MySQL 為背景,很多內(nèi)容同時(shí)適用于其他關(guān)系型數(shù)據(jù)庫,需要有一些索引知識(shí)為基礎(chǔ),重點(diǎn)講述如何優(yōu)化SQL,來提高數(shù)據(jù)庫的性能
    2012-01-01
  • mysql導(dǎo)入導(dǎo)出數(shù)據(jù)中文亂碼解決方法小結(jié)

    mysql導(dǎo)入導(dǎo)出數(shù)據(jù)中文亂碼解決方法小結(jié)

    本文章總結(jié)了mysql導(dǎo)入導(dǎo)出數(shù)據(jù)中文亂碼解決方法,出現(xiàn)中文亂碼一般情況是導(dǎo)入導(dǎo)入時(shí)編碼的設(shè)置問題,我們只要把編碼調(diào)整一致即可解決此方法,下面是搜索到的一些方法總結(jié),方便需要的朋友
    2012-10-10
  • MySQL鎖阻塞的深入分析

    MySQL鎖阻塞的深入分析

    這篇文章主要給大家介紹了關(guān)于MySQL鎖阻塞的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Mysql 錯(cuò)誤too many connections解決方案

    Mysql 錯(cuò)誤too many connections解決方案

    這篇文章主要介紹了Mysql 錯(cuò)誤too many connections解決方案的相關(guān)資料,這里提供了如何解決此問題,需要的朋友可以參考下
    2016-11-11
  • 解析sql語句中l(wèi)eft_join、inner_join中的on與where的區(qū)別

    解析sql語句中l(wèi)eft_join、inner_join中的on與where的區(qū)別

    以下是對(duì)在sql語句中l(wèi)eft_join、inner_join中的on與where的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以參考下
    2013-07-07
  • MySQL之where使用詳解

    MySQL之where使用詳解

    我們需要獲取數(shù)據(jù)庫表數(shù)據(jù)的特定子集時(shí),可以使用where子句指定搜索條件進(jìn)行過濾。本文主要介紹了MySQL之where使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • mysql亂碼問題分析與解決方法

    mysql亂碼問題分析與解決方法

    開發(fā)過程中總避免不了遇到惡心的亂碼,或者由亂碼引發(fā)的一系列問題,這里簡(jiǎn)要介紹一下自己遇到的亂碼問題和解決問題的過程中的想法以及大致的操作
    2012-11-11
  • MySQL分區(qū)字段列有必要再單獨(dú)建索引嗎?

    MySQL分區(qū)字段列有必要再單獨(dú)建索引嗎?

    這篇文章主要給大家介紹了關(guān)于MySQL分區(qū)字段列是否有必要再單獨(dú)建索引的相關(guān)資料,文中通過示例進(jìn)行了驗(yàn)證,對(duì)大家的理解和學(xué)習(xí)具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • innodb_flush_method取值方法(實(shí)例講解)

    innodb_flush_method取值方法(實(shí)例講解)

    下面小編就為大家?guī)硪黄猧nnodb_flush_method取值方法(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03

最新評(píng)論