如果你同時執行表格的檢查/修復程式時,你或許不想讓MySQL伺服器 和實用程式同時存取一個表格。如果兩個程式都寫資料在表中顯然會造成很大的麻煩,甚至會有意外情況發生。如果表正由一個程式寫入,同時進行讀取的另一個程式也會產生混亂的結果。本文主要講述如何對MySQL資料庫表進行鎖定。
鎖定表的方法
防止客戶機的請求互相干擾或伺服器與維護程序相互幹擾的方法主要有多種。如果你關閉資料庫,你可以確保伺服器和myisamchk和 isamchk之間沒有交互作用。但是停止伺服器的運作並不是一個好注意,因為這樣做會讓沒有故障的資料庫和表格也不可用。本節主要討論的過程,是避免伺服器和myisamchk或isamchk之間的交互作用。實現這種功能的方法是對錶進行鎖定。
伺服器由兩種表的鎖定方法:
1.內部鎖定
內部鎖定可以避免客戶機的請求相互幹擾-例如,避免客戶機的SELECT查詢被另一個客戶機的UPDATE查詢所干擾。也可以利用內部鎖定機制來防止伺服器在利用myisamchk或isamchk檢查或修復表格時對資料表的存取。
語法:
鎖定表:LOCK TABLES tbl_name {READ | WRITE},[ tbl_name {READ | WRITE},…]
解鎖表:UNLOCK TABLES
LOCK TABLES為目前執行緒表鎖定。 UNLOCK TABLES釋放被目前執行緒持有的任何鎖。當執行緒發出另外一個LOCK TABLES時,或當伺服器的連線被關閉時,當前執行緒鎖定的所有表會自動解鎖。
如果一個執行緒獲得在一個表上的一個READ鎖,該執行緒(和所有其他執行緒)只能從表中讀取。如果一個執行緒取得一個表格上的一個WRITE鎖,那麼只有持鎖的執行緒READ或WRITE表,其他執行緒被阻止。
每個執行緒等待(沒有超時)直到它獲得它所要求的所有鎖。
WRITE鎖通常比READ鎖有更高的優先級,以確保變更盡快被處理。這意味著,如果一個執行緒獲得READ鎖,並且然後另一個執行緒請求一個WRITE鎖, 隨後的READ鎖定請求將等待直到WRITE執行緒得到了鎖並且釋放了它。
顯然對於檢查,你只需要獲得讀鎖。再者鍾情跨下,只能讀取表,但不能修改它,因此他也允許其它客戶機讀取表。對於修復,你必須獲得些所以防止任何客戶機在你對錶進行操作時修改它。
2.外部鎖定
伺服器還可以使用外部鎖定(檔案 級鎖定)來防止其它程式在伺服器使用表時修改檔案。通常,在表格的檢查作業中伺服器將外部鎖定與myisamchk或 isamchk作合使用。但是,外部鎖定在某些系統 中是禁用的,因為他不能可靠的進行工作。執行myisamchk或isamchk所選擇的過程取決於伺服器是否能使用外部鎖定。如果不使用,則必修使用內部鎖定協定。
如果伺服器用--skip-locking選項運行,則外部鎖定停用。此選項在某些系統中是缺省的,如Linux。可以透過執行mysql admin variables指令來確定伺服器是否能夠使用外部鎖定。檢查skip_locking變數的值並按以下方法進行:
如果skip_locking為off,則外部鎖定有效您可以繼續並運行人和一個實用程式來檢查表。伺服器和實用程式將合作對錶進行存取。但是,在運行任何一個實用程式之前,應該使用mysqladmin flush-tables。為了修復表,應該使用表的修復鎖定協定。
如果skip_locaking為on,則停用外部鎖定,所以在myisamchk或isamchk檢查修復表示伺服器並不知道,最好關閉伺服器。如果堅持是伺服器保持開啟狀態,月確保在您使用此表示沒有客戶機來存取它。必須使用卡黨的鎖定協定告訴伺服器是該表不被其他客戶機存取。
檢查表的鎖定協定
本節只介紹如果使用表的內部鎖定。對於檢查表的鎖定協議,此過程只針對表的檢查,不針對表的修復。
1.呼叫mysql發布下列語句:
$mysql –u root –p db_namemysql>LOCK TABLE tbl_name READ;mysql>FLUSH TABLES;
該鎖防止其它客戶機在檢查時寫入該表和修改該表。 FLUSH語句導致伺服器關閉表的文件,它將刷新仍在告訴快取中的任何寫入的改變。
2.執行檢查過程
$myisamchk tbl_name$ isamchk tbl_name
3.釋放表鎖
mysql>UNLOCK TABLES;
如果myisisam
mysql>UNLOCK TABLES;