日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql锁表解决

發布時間:2024/9/15 数据库 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql锁表解决 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

主要使前三條語句,來看是否還存在鎖表

show OPEN TABLES where In_use > 0; -- 查詢是否鎖表 show processlist; -- 查詢到相對應的進程===然后killid kill id; -- 殺進程 SELECT * FROM INFORMATION_SCHEMA.innodb_trx; -- 當前運行的所有事務 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 查看正在鎖的事務 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; -- 查看等待鎖的事務

MySQL鎖概述

相對其他數據庫而言,MySQL的鎖機制比較簡單,其最顯著的特點是不同的存儲引擎支持不同的鎖機制。比如,MyISAM和MEMORY存儲引擎采用的是表級鎖(table-level locking);BDB存儲引擎采用的是頁面鎖(page-level locking),但也支持表級鎖;InnoDB存儲引擎既支持行級鎖(row-level locking),也支持表級鎖,但默認情況下是采用行級鎖。

MySQL這3種鎖的特性可大致歸納如下。

開銷、加鎖速度、死鎖、粒度、并發性能

  • l 表級鎖:開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發生鎖沖突的概率最高,并發度最低。

  • l 行級鎖:開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖沖突的概率最低,并發度也最高。

  • l 頁面鎖:開銷和加鎖時間界于表鎖和行鎖之間;會出現死鎖;鎖定粒度界于表鎖和行鎖之間,并發度一般。

MyISAM表鎖

MyISAM存儲引擎只支持表鎖,這也是MySQL開始幾個版本中唯一支持的鎖類型。隨著應用對事務完整性和并發性要求的不斷提高,MySQL才開始開發基于事務的存儲引擎,后來慢慢出現了支持頁鎖的BDB存儲引擎和支持行鎖的InnoDB存儲引擎(實際 InnoDB是單獨的一個公司,現在已經被Oracle公司收購)。但是MyISAM的表鎖依然是使用最為廣泛的鎖類型。本節將詳細介紹MyISAM表鎖的使用。
查詢表級鎖爭用情況
可以通過檢查table_locks_waited和table_locks_immediate狀態變量來分析系統上的表鎖定爭奪:

mysql> show status like 'table%'; +-----------------------+-------+ | Variable_name | Value | +-----------------------+-------+ | Table_locks_immediate | 2979 | | Table_locks_waited | 0 | +-----------------------+-------+ 2 rows in set (0.00 sec))

如果Table_locks_waited的值比較高,則說明存在著較嚴重的表級鎖爭用情況。

獲取InnoDB行鎖爭用情況

可以通過檢查InnoDB_row_lock狀態變量來分析系統上的行鎖的爭奪情況:

mysql> show status like 'innodb_row_lock%'; +-------------------------------+-------+ | Variable_name | Value | +-------------------------------+-------+ | InnoDB_row_lock_current_waits | 0 | | InnoDB_row_lock_time | 0 | | InnoDB_row_lock_time_avg | 0 | | InnoDB_row_lock_time_max | 0 | | InnoDB_row_lock_waits | 0 | +-------------------------------+-------+ 5 rows in set (0.01 sec)

如果發現鎖爭用比較嚴重,如InnoDB_row_lock_waits和InnoDB_row_lock_time_avg的值比較高,還可以通過

解鎖

第一種

show processlist;

找到鎖進程,kill id ;

第二種

mysql>UNLOCK TABLES;

鎖表

鎖定數據表,避免在備份過程中,表被更新

mysql>LOCK TABLES tbl_name READ;

為表增加一個寫鎖定:

mysql>LOCK TABLES tbl_name WRITE;

###########################################################################

mysql優化——show processlist命令詳解

2017年04月24日 10:53:53 菜鳥里根 閱讀數:29594

版權聲明:本文為博主原創文章,未經博主允許不得轉載。 https://blog.csdn.net/sunqingzhong44/article/details/70570728
SHOW PROCESSLIST顯示哪些線程正在運行

不在mysql提示符下使用時用mysql -uroot -e 'Show processlist' 或者 mysqladmin processlist

如果您有root權限,您可以看到所有線程。否則,您只能看到登錄的用戶自己的線程,通常只會顯示100條如果想看跟多的可以使用full修飾(show full processlist)

參數

  • id #ID標識,要kill一個語句的時候很有用
  • use #當前連接用戶
  • host #顯示這個連接從哪個ip的哪個端口上發出
  • db #數據庫名
  • command #連接狀態,一般是休眠(sleep),查詢(query),連接(connect)
  • time #連接持續時間,單位是秒
  • state #顯示當前sql語句的狀態
  • info #顯示這個sql語句

其中state的狀態十分關鍵,下表列出state主要狀態和描述:

狀態 描述
Checking table 正在檢查數據表(這是自動的)。
Closing tables 正在將表中修改的數據刷新到磁盤中,同時正在關閉已經用完的表。這是一個很快的操作,如果不是這樣的話,就應該確認磁盤空間是否已經滿了或者磁盤是否正處于重負中。
Connect Out 復制從服務器正在連接主服務器。
Copying to tmp table on disk 由于臨時結果集大于tmp_table_size,正在將臨時表從內存存儲轉為磁盤存儲以此節省內存。
Creating tmp table 正在創建臨時表以存放部分查詢結果。
deleting from main table 服務器正在執行多表刪除中的第一部分,剛刪除第一個表。
deleting from reference tables 服務器正在執行多表刪除中的第二部分,正在刪除其他表的記錄。
Flushing tables 正在執行FLUSH TABLES,等待其他線程關閉數據表。
Killed 發送了一個kill請求給某線程,那么這個線程將會檢查kill標志位,同時會放棄下一個kill請求。MySQL會在每次的主循環中檢查kill標志位,不過有些情況下該線程可能會過一小段才能死掉。如果該線程程被其他線程鎖住了,那么kill請求會在鎖釋放時馬上生效。

Locked 被其他查詢鎖住了。

Sending data 正在處理SELECT查詢的記錄,同時正在把結果發送給客戶端。
Sorting for group 正在為GROUP BY做排序。
Sorting for order 正在為ORDER BY做排序。
Opening tables 這個過程應該會很快,除非受到其他因素的干擾。例如,在執ALTER TABLE或LOCK TABLE語句行完以前,數據表無法被其他線程打開。正嘗試打開一個表。
Removing duplicates 正在執行一個SELECT DISTINCT方式的查詢,但是MySQL無法在前一個階段優化掉那些重復的記錄。因此,MySQL需要再次去掉重復的記錄,然后再把結果發送給客戶端。

Reopen table 獲得了對一個表的鎖,但是必須在表結構修改之后才能獲得這個鎖。已經釋放鎖,關閉數據表,正嘗試重新打開數據表。
Repair by sorting 修復指令正在排序以創建索引。
Repair with keycache 修復指令正在利用索引緩存一個一個地創建新索引。它會比Repair by sorting慢些。
Searching rows for update 正在講符合條件的記錄找出來以備更新。它必須在UPDATE要修改相關的記錄之前就完成了。
Sleeping 正在等待客戶端發送新請求.
System lock 正在等待取得一個外部的系統鎖。如果當前沒有運行多個mysqld服務器同時請求同一個表,那么可以通過增加--skip-external-locking參數來禁止外部系統鎖。
Upgrading lock INSERT DELAYED正在嘗試取得一個鎖表以插入新記錄。
Updating 正在搜索匹配的記錄,并且修改它們。
User Lock 正在等待GET_LOCK()。
Waiting for tables 該線程得到通知,數據表結構已經被修改了,需要重新打開數據表以取得新的結構。然后,為了能的重新打開數據表,必須等到所有其他線程關閉這個表。以下幾種情況下會產生這個通知:FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE,或OPTIMIZE TABLE。
waiting for handler insert INSERT DELAYED已經處理完了所有待處理的插入操作,正在等待新的請求。
mysql手冊鏈接:http://dev.mysql.com/doc/refman/5.0/en/general-thread-states.html

總結

以上是生活随笔為你收集整理的mysql锁表解决的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。