偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

如何對(duì)MySQL數(shù)據(jù)庫(kù)表進(jìn)行鎖定

運(yùn)維 數(shù)據(jù)庫(kù)運(yùn)維 MySQL
如果你同時(shí)運(yùn)行表的檢查/修復(fù)程序時(shí),你或許不想讓MySQL服務(wù)器和實(shí)用程序同時(shí)訪問(wèn)一個(gè)表。如果兩個(gè)程序都向表中寫(xiě)數(shù)據(jù)顯然會(huì)造成很大的麻煩,甚至?xí)幸馔馇闆r發(fā)生。如果表正由一個(gè)程序?qū)懭耄瑫r(shí)進(jìn)行讀取的另一個(gè)程序也會(huì)產(chǎn)生混亂的結(jié)果。本文主要講述如何對(duì)MySQL數(shù)據(jù)庫(kù)表進(jìn)行鎖定。

相關(guān)文章:

如何進(jìn)行MySQL數(shù)據(jù)庫(kù)表的故障檢測(cè)

如何修復(fù)MySQL數(shù)據(jù)庫(kù)表

鎖定表的方法

防止客戶機(jī)的請(qǐng)求互相干擾或者服務(wù)器與維護(hù)程序相互干擾的方法主要有多種。如果你關(guān)閉數(shù)據(jù)庫(kù),就可以保證服務(wù)器和myisamchk和isamchk之間沒(méi)有交互作用。但是停止服務(wù)器的運(yùn)行并不是一個(gè)好注意,因?yàn)檫@樣做會(huì)使得沒(méi)有故障的數(shù)據(jù)庫(kù)和表也不可用。本節(jié)主要討論的過(guò)程,是避免服務(wù)器和myisamchk或isamchk之間的交互作用。實(shí)現(xiàn)這種功能的方法是對(duì)表進(jìn)行鎖定。

服務(wù)器由兩種表的鎖定方法:

1.內(nèi)部鎖定

內(nèi)部鎖定可以避免客戶機(jī)的請(qǐng)求相互干擾——例如,避免客戶機(jī)的SELECT查詢被另一個(gè)客戶機(jī)的UPDATE查詢所干擾。也可以利用內(nèi)部鎖定機(jī)制防止服務(wù)器在利用myisamchk或isamchk檢查或修復(fù)表時(shí)對(duì)表的訪問(wèn)。

語(yǔ)法:

鎖定表:LOCK TABLES tbl_name {READ | WRITE},[ tbl_name {READ | WRITE},…]

解鎖表:UNLOCK TABLES

LOCK TABLES為當(dāng)前線程鎖定表。UNLOCK TABLES釋放被當(dāng)前線程持有的任何鎖。當(dāng)線程發(fā)出另外一個(gè)LOCK TABLES時(shí),或當(dāng)服務(wù)器的連接被關(guān)閉時(shí),當(dāng)前線程鎖定的所有表自動(dòng)被解鎖。

如果一個(gè)線程獲得在一個(gè)表上的一個(gè)READ鎖,該線程(和所有其他線程)只能從表中讀。如果一個(gè)線程獲得一個(gè)表上的一個(gè)WRITE鎖,那么只有持鎖的線程READ或WRITE表,其他線程被阻止。

每個(gè)線程等待(沒(méi)有超時(shí))直到它獲得它請(qǐng)求的所有鎖。

WRITE鎖通常比READ鎖有更高的優(yōu)先級(jí),以確保更改盡快被處理。這意味著,如果一個(gè)線程獲得READ鎖,并且然后另外一個(gè)線程請(qǐng)求一個(gè)WRITE鎖, 隨后的READ鎖請(qǐng)求將等待直到WRITE線程得到了鎖并且釋放了它。

顯然對(duì)于檢查,你只需要獲得讀鎖。再者鐘情跨下,只能讀取表,但不能修改它,因此他也允許其它客戶機(jī)讀取表。對(duì)于修復(fù),你必須獲得些所以防止任何客戶機(jī)在你對(duì)表進(jìn)行操作時(shí)修改它。

2.外部鎖定

服務(wù)器還可以使用外部鎖定(文件級(jí)鎖)來(lái)防止其它程序在服務(wù)器使用表時(shí)修改文件。通常,在表的檢查操作中服務(wù)器將外部鎖定與myisamchk或isamchk作合使用。但是,外部鎖定在某些系統(tǒng)中是禁用的,因?yàn)樗荒芸煽康倪M(jìn)行工作。對(duì)運(yùn)行myisamchk或isamchk所選擇的過(guò)程取決于服務(wù)器是否能使用外部鎖定。如果不使用,則必修使用內(nèi)部鎖定協(xié)議。
如果服務(wù)器用--skip-locking選項(xiàng)運(yùn)行,則外部鎖定禁用。該選項(xiàng)在某些系統(tǒng)中是缺省的,如Linux??梢酝ㄟ^(guò)運(yùn)行mysqladmin variables命令確定服務(wù)器是否能夠使用外部鎖定。檢查skip_locking變量的值并按以下方法進(jìn)行:

◆ 如果skip_locking為off,則外部鎖定有效您可以繼續(xù)并運(yùn)行人和一個(gè)實(shí)用程序來(lái)檢查表。服務(wù)器和實(shí)用程序?qū)⒑献鲗?duì)表進(jìn)行訪問(wèn)。但是,運(yùn)行任何一個(gè)實(shí)用程序之前,應(yīng)該使用mysqladmin flush-tables。為了修復(fù)表,應(yīng)該使用表的修復(fù)鎖定協(xié)議。

◆ 如果skip_locaking為on,則禁用外部鎖定,所以在myisamchk或isamchk檢查修復(fù)表示服務(wù)器并不知道,最好關(guān)閉服務(wù)器。如果堅(jiān)持是服務(wù)器保持開(kāi)啟狀態(tài),月確保在您使用此表示沒(méi)有客戶機(jī)來(lái)訪問(wèn)它。必須使用卡黨的鎖定協(xié)議告訴服務(wù)器是該表不被其他客戶機(jī)訪問(wèn)。

檢查表的鎖定協(xié)議

本節(jié)只介紹如果使用表的內(nèi)部鎖定。對(duì)于檢查表的鎖定協(xié)議,此過(guò)程只針對(duì)表的檢查,不針對(duì)表的修復(fù)。

1.調(diào)用mysql發(fā)布下列語(yǔ)句:

$mysql –u root –p db_name

mysql>LOCK TABLE tbl_name READ;

mysql>FLUSH TABLES;

該鎖防止其它客戶機(jī)在檢查時(shí)寫(xiě)入該表和修改該表。FLUSH語(yǔ)句導(dǎo)致服務(wù)器關(guān)閉表的文件,它將刷新仍在告訴緩存中的任何為寫(xiě)入的改變。

2.執(zhí)行檢查過(guò)程

$myisamchk tbl_name

$ isamchk tbl_name

3.釋放表鎖

mysql>UNLOCK TABLES;

如果myisamchk或isamchk指出發(fā)現(xiàn)該表的問(wèn)題,將需要執(zhí)行表的修復(fù)。

修復(fù)表的鎖定協(xié)議

這里只介紹如果使用表的內(nèi)部鎖定。修復(fù)表的鎖定過(guò)程類似于檢查表的鎖定過(guò)程,但有兩個(gè)區(qū)別。第一,你必須得到寫(xiě)鎖而非讀鎖。由于你需要修改表,因此根本不允許客戶機(jī)對(duì)其進(jìn)行訪問(wèn)。第二,必須在執(zhí)行修復(fù)之后發(fā)布FLUSH TABLE語(yǔ)句,因?yàn)閙yisamchk和isamchk建立的新的索引文件,除非再次刷新改表的高速緩存,否則服務(wù)器不會(huì)注意到這個(gè)改變。本例同樣適合優(yōu)化表的過(guò)程。

1.調(diào)用mysql發(fā)布下列語(yǔ)句:

$mysql –u root –p db_name

mysql>LOCK TABLE tbl_name WRITE;

mysql>FLUSH TABLES;

2.做數(shù)據(jù)表的拷貝,然后運(yùn)行myisamchk和isamchk:

$cp tbl_name.* /some/other/dir

$myisamchk --recover tbl_name

$ isamchk --recover tbl_name

--recover選項(xiàng)只是針對(duì)安裝而設(shè)置的。這些特殊選項(xiàng)的選擇將取決與你執(zhí)行修復(fù)的類型。

3.再次刷新高速緩存,并釋放表鎖:

mysql>FLUSH TABLES;

mysql>UNLOCK TABLES;

【編輯推薦】

  1. 如何進(jìn)行MySQL數(shù)據(jù)庫(kù)表的故障檢測(cè)
  2. 如何修復(fù)MySQL數(shù)據(jù)庫(kù)表
  3. 如何對(duì)MySQL數(shù)據(jù)庫(kù)日志文件進(jìn)行維護(hù)
  4. 建立MySQL數(shù)據(jù)庫(kù)日常維護(hù)規(guī)范
  5. 如何在.NET中使用MySQL數(shù)據(jù)庫(kù)
責(zé)任編輯:楊鵬飛 來(lái)源: 51CTO整理
相關(guān)推薦

2011-05-18 13:16:21

MySQL數(shù)據(jù)庫(kù)鎖定

2023-09-14 23:05:57

? ?MySQL數(shù)據(jù)庫(kù)

2010-05-24 14:57:03

MySQL數(shù)據(jù)庫(kù)表

2009-02-02 17:21:58

日志文件維護(hù)MySQL日志文件

2010-05-18 11:04:11

MySQL數(shù)據(jù)庫(kù)

2010-06-01 16:35:43

MySQL數(shù)據(jù)庫(kù)

2009-02-02 13:43:19

故障檢測(cè)數(shù)據(jù)庫(kù)

2018-05-10 17:18:59

數(shù)據(jù)庫(kù)MySQL密碼

2009-02-02 13:16:23

修復(fù)數(shù)據(jù)表MySQL

2019-02-28 21:20:50

MySQL備份與恢復(fù)數(shù)據(jù)庫(kù)

2010-05-31 18:24:53

MySQL數(shù)據(jù)庫(kù)

2010-10-13 09:30:45

SQL Server

2010-02-02 15:48:49

Python數(shù)據(jù)庫(kù)

2018-02-26 20:00:00

編程語(yǔ)言JavaMySQL

2010-06-12 15:53:22

MySQL數(shù)據(jù)庫(kù)

2010-05-13 17:41:58

2010-05-21 09:13:01

MySQL數(shù)據(jù)庫(kù)查詢

2011-03-15 14:36:04

MyisamchkMySQL數(shù)據(jù)表

2010-10-13 11:59:50

MySQL表命名

2022-06-06 08:21:13

MySQL數(shù)據(jù)庫(kù)命令
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)