這篇文章主要講解了“怎么理解MySQL中FLUSH TABLES和FLUSH TABLES WITH READ LOCK”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“怎么理解mysql中FLUSH TABLES和FLUSH TABLES WITH READ LOCK”吧!
創(chuàng)新互聯(lián)專注于企業(yè)成都全網(wǎng)營(yíng)銷、網(wǎng)站重做改版、茄子河網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站、商城網(wǎng)站開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為茄子河等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
1、FLUSH TABLES關(guān)閉所有打開的表,強(qiáng)制關(guān)閉所有正在使用的表,并刷新查詢緩存和預(yù)準(zhǔn)備語(yǔ)句緩存,不會(huì)刷新臟塊
2、FLUSH TABLES WITH READ LOCK關(guān)閉所有打開的表并使用全局讀鎖鎖定所有數(shù)據(jù)庫(kù)的所有表,不會(huì)刷新臟塊
3、如果一個(gè)會(huì)話中使用LOCK TABLES tbl_name lock_type語(yǔ)句對(duì)某表加了表鎖,在該表鎖未釋放前,那么另外一個(gè)會(huì)話如果執(zhí)行FLUSH TABLES語(yǔ)句會(huì)被阻塞,執(zhí)行FLUSH TABLES WITH READ LOCK也會(huì)被堵塞
4、如果一個(gè)會(huì)話正在執(zhí)行DDL語(yǔ)句,那么另外一個(gè)會(huì)話如果執(zhí)行FLUSH TABLES 語(yǔ)句會(huì)被阻塞 ,執(zhí)行FLUSH TABLES WITH READ LOCK也會(huì)被堵塞
5、如果一個(gè)會(huì)話正在執(zhí)行DML大事務(wù)(DML語(yǔ)句正在執(zhí)行,數(shù)據(jù)正在發(fā)生修改,而不是使用lock in share mode和for update語(yǔ)句來(lái)顯式加鎖),那么另外一個(gè)會(huì)話如果執(zhí)行FLUSH TABLES語(yǔ)句會(huì)被阻塞,執(zhí)行FLUSH TABLES WITH READ LOCK也會(huì)被堵塞
6、FLUSH TABLES WITH READ LOCK語(yǔ)句不會(huì)阻塞日志表的寫入,例如:查詢?nèi)罩荆樵內(nèi)罩镜?
7、mysqldump的--master-data、--lock-all-tables參數(shù)引發(fā)FLUSH TABLES和FLUSH TABLES WITH READ LOCK
8、FLUSH TABLES tbl_name [, tbl_name] ... FOR EXPORT 會(huì)刷新臟塊
9、FLUSH TABLES WITH READ LOCK可以針對(duì)單個(gè)表進(jìn)行鎖定,比如只鎖定table1則flush tables table1 with read lock;
FLUSH TABLES
https://dev.mysql.com/doc/refman/5.7/en/flush.html#flush-tables
Closes all open tables, forces all tables in use to be closed, and flushes the query cache and prepared statement cache. FLUSH TABLES also removes all query results from the query cache, like the RESET QUERY CACHE statement.
關(guān)閉所有打開的表,強(qiáng)制關(guān)閉所有正在使用的表,并刷新查詢緩存和預(yù)準(zhǔn)備語(yǔ)句緩存。 FLUSH TABLES還會(huì)從查詢緩存中刪除所有查詢結(jié)果,例如RESET QUERY CACHE語(yǔ)句。
RESET QUERY CACHE
https://dev.mysql.com/doc/refman/5.7/en/query-cache.html
The query cache stores the text of a SELECT statement together with the corresponding result that was sent to the client. If an identical statement is received later, the server retrieves the results from the query cache rather than parsing and executing the statement again. The query cache is shared among sessions, so a result set generated by one client can be sent in response to the same query issued by another client.
The query cache can be useful in an environment where you have tables that do not change very often and for which the server receives many identical queries. This is a typical situation for many Web servers that generate many dynamic pages based on database content.
The query cache does not return stale data. When tables are modified, any relevant entries in the query cache are flushed.
查詢緩存存儲(chǔ)SELECT語(yǔ)句的文本以及發(fā)送到客戶端的相應(yīng)結(jié)果。 如果稍后收到相同的語(yǔ)句,則服務(wù)器從查詢緩存中檢索結(jié)果,而不是再次解析和執(zhí)行語(yǔ)句。 查詢緩存在會(huì)話之間共享,因此可以發(fā)送由一個(gè)客戶端生成的結(jié)果集以響應(yīng)由另一個(gè)客戶端發(fā)出的相同查詢。
查詢緩存在您擁有不經(jīng)常更改且服務(wù)器接收許多相同查詢的表的環(huán)境中非常有用。 這是許多基于數(shù)據(jù)庫(kù)內(nèi)容生成許多動(dòng)態(tài)頁(yè)面的Web服務(wù)器的典型情況。
查詢緩存不返回過(guò)時(shí)數(shù)據(jù)。 修改表時(shí),將刷新查詢緩存中的所有相關(guān)條目。
FLUSH TABLES is not permitted when there is an active LOCK TABLES ... READ. To flush and lock tables, use FLUSH TABLES tbl_name ... WITH READ LOCK instead.
當(dāng)有表正處于LOCK TABLES … READ語(yǔ)句加鎖狀態(tài)時(shí),不允許使用FLUSH TABLES語(yǔ)句(另外一個(gè)會(huì)話執(zhí)行FLUSH TABLES會(huì)被阻塞),如果已經(jīng)使用LOCK TABLES … READ語(yǔ)句對(duì)某表加讀鎖的情況下要對(duì)另外的表執(zhí)行刷新,可以在另外一個(gè)會(huì)話中使用FLUSH TABLES tbl_name … WITH READ LOCK語(yǔ)句
會(huì)話1先執(zhí)行
mysql> lock tables table1 read ;
會(huì)話2,堵塞
mysql> flush tables ;
會(huì)話3,堵塞
mysql> flush tables table1 with read lock;
會(huì)話4,不堵塞
mysql> flush tables table2 with read lock;
FLUSH TABLES tbl_name [, tbl_name] ...
With a list of one or more comma-separated table names, this statement is like FLUSH TABLES with no names except that the server flushes only the named tables. If a named table does not exist, no error occurs.
使用一個(gè)或多個(gè)逗號(hào)分隔的表名列表,表示只刷新這些表名的表,如果命名表不存在,則不會(huì)發(fā)生錯(cuò)誤。
FLUSH TABLES WITH READ LOCK
Closes all open tables and locks all tables for all databases with a global read lock. This is a very convenient way to get backups if you have a file system such as Veritas or ZFS that can take snapshots in time. Use UNLOCK TABLES to release the lock.
關(guān)閉所有打開的表并使用全局讀鎖鎖定所有數(shù)據(jù)庫(kù)的所有表。 如果您具有可以及時(shí)拍攝快照的Veritas或ZFS等文件系統(tǒng),則這是一種非常方便的備份方式。 使用UNLOCK TABLES釋放鎖定。(你可以及時(shí)使用支持快照的文件系統(tǒng)進(jìn)行快照備份,備份完成之后,使用UNLOCK TABLES語(yǔ)句釋放鎖。)
FLUSH TABLES WITH READ LOCK acquires a global read lock rather than table locks, so it is not subject to the same behavior as LOCK TABLES and UNLOCK TABLES with respect to table locking and implicit commits:
UNLOCK TABLES implicitly commits any active transaction only if any tables currently have been locked with LOCK TABLES. The commit does not occur for UNLOCK TABLES following FLUSH TABLES WITH READ LOCK because the latter statement does not acquire table locks.
Beginning a transaction causes table locks acquired with LOCK TABLES to be released, as though you had executed UNLOCK TABLES. Beginning a transaction does not release a global read lock acquired with FLUSH TABLES WITH READ LOCK.
FLUSH TABLES WITH READ LOCK獲取全局讀鎖而不是表鎖,因此在表鎖定和隱式提交方面,表現(xiàn)行為不會(huì)像LOCK TABLES和UNLOCK TABLES語(yǔ)句:
當(dāng)前任何表已被LOCK TABLES tbl_name lock_type語(yǔ)句鎖定時(shí),UNLOCK TABLES會(huì)隱式提交任何活動(dòng)事務(wù)。但是執(zhí)行FLUSH TABLES WITH READ LOCK之后,再執(zhí)行UNLOCK TABLES不會(huì)發(fā)生提交,因?yàn)楹笠粋€(gè)語(yǔ)句沒(méi)有獲取表鎖。
開始事務(wù)會(huì)導(dǎo)致釋放使用LOCK TABLES tbl_name lock_type語(yǔ)句獲取的表鎖,就像您已經(jīng)執(zhí)行了UNLOCK TABLES一 樣。 開始事務(wù)不會(huì)釋放使用FLUSH TABLES WITH READ LOCK獲取的全局讀鎖定。
FLUSH TABLES WITH READ LOCK is not compatible with XA transactions.
FLUSH TABLES WITH READ LOCK does not prevent the server from inserting rows into the log tables
FLUSH TABLES WITH READ LOCK 與XA事務(wù)不兼容。
FLUSH TABLES WITH READ LOCK 不會(huì)阻止服務(wù)器將行插入日志表,例如:查詢?nèi)罩?,慢查詢?nèi)罩镜?/p>
FLUSH TABLES tbl_name [, tbl_name] ... WITH READ LOCK
This statement flushes and acquires read locks for the named tables. The statement first acquires exclusive metadata locks for the tables, so it waits for transactions that have those tables open to complete. Then the statement flushes the tables from the table cache, reopens the tables, acquires table locks (like LOCK TABLES ... READ), and downgrades the metadata locks from exclusive to shared. After the statement acquires locks and downgrades the metadata locks, other sessions can read but not modify the tables.
Because this statement acquires table locks, you must have the LOCK TABLES privilege for each table, in addition to the RELOAD privilege that is required to use any FLUSH statement.
This statement applies only to existing base (non-TEMPORARY) tables. If a name refers to a base table, that table is used. If it refers to a TEMPORARY table, it is ignored. If a name applies to a view, an ER_WRONG_OBJECT error occurs. Otherwise, an ER_NO_SUCH_TABLE error occurs.
Use UNLOCK TABLES to release the locks, LOCK TABLES to release the locks and acquire other locks, or START TRANSACTION to release the locks and begin a new transaction.
This FLUSH TABLES variant enables tables to be flushed and locked in a single operation. It provides a workaround for the restriction that FLUSH TABLES is not permitted when there is an active LOCK TABLES ... READ.
This statement does not perform an implicit UNLOCK TABLES, so an error results if you use the statement while there is any active LOCK TABLES or use it a second time without first releasing the locks acquired.
If a flushed table was opened with HANDLER, the handler is implicitly flushed and loses its position.
此語(yǔ)句刷新并獲取指定表的讀鎖定。 該語(yǔ)句首先獲取表的獨(dú)占元數(shù)據(jù)鎖,因此它等待打開這些表的事務(wù)完成。 然后語(yǔ)句從表緩存中刷新表,重新打開表,獲取表鎖(如LOCK TABLES ... READ),并將元數(shù)據(jù)鎖從獨(dú)占降級(jí)為共享。 在語(yǔ)句獲取鎖并降級(jí)元數(shù)據(jù)鎖后,其他會(huì)話可以讀取但不能修改表。
由于此語(yǔ)句獲取表鎖,因此除了使用任何FLUSH語(yǔ)句所需的RELOAD權(quán)限外,還必須為每個(gè)表具有LOCK TABLES權(quán)限。
此語(yǔ)句僅適用于現(xiàn)有的基本(非TEMPORARY)表。 如果名稱引用基本表,則使用該基本表。 如果它引用TEMPORARY表,則忽略它。 如果名稱適用于視圖,則會(huì)發(fā)生ER_WRONG_OBJECT錯(cuò)誤。 否則,發(fā)生ER_NO_SUCH_TABLE錯(cuò)誤。
使用UNLOCK TABLES釋放鎖,使用LOCK TABLES釋放該鎖并獲取其他鎖,或使用START TRANSACTION釋放鎖并開始新的事務(wù)。
此FLUSH TABLES變量使表能夠在單個(gè)操作中刷新和鎖定。 它提供了一個(gè)解決方法,當(dāng)有一個(gè)活動(dòng)的LOCK TABLES ... READ時(shí),不允許FLUSH TABLES。
此語(yǔ)句不執(zhí)行隱式UNLOCK TABLES,因此如果在有任何活動(dòng)的LOCK TABLES時(shí)使用該語(yǔ)句,或者在沒(méi)有首先釋放獲取的鎖的情況下再次使用該語(yǔ)句,則會(huì)導(dǎo)致錯(cuò)誤。
如果使用HANDLER打開已刷新的表,則會(huì)隱式刷新處理程序并丟失其位置。
FLUSH TABLES tbl_name [, tbl_name] ... FOR EXPORT
This FLUSH TABLES variant applies to InnoDB tables. It ensures that changes to the named tables have been flushed to disk so that binary table copies can be made while the server is running.
The statement works like this:
a.It acquires shared metadata locks for the named tables. The statement blocks as long as other sessions have active transactions that have modified those tables or hold table locks for them. When the locks have been acquired, the statement blocks transactions that attempt to update the tables, while permitting read-only operations to continue.
b.It checks whether all storage engines for the tables support FOR EXPORT. If any do not, an ER_ILLEGAL_HA error occurs and the statement fails.
c.The statement notifies the storage engine for each table to make the table ready for export. The storage engine must ensure that any pending changes are written to disk.
d.The statement puts the session in lock-tables mode so that the metadata locks acquired earlier are not released when the FOR EXPORT statement completes.
The FLUSH TABLES ... FOR EXPORT statement requires that you have the SELECT privilege for each table. Because this statement acquires table locks, you must also have the LOCK TABLES privilege for each table, in addition to the RELOAD privilege that is required to use any FLUSH statement.
This statement applies only to existing base (non-TEMPORARY) tables. If a name refers to a base table, that table is used. If it refers to a TEMPORARY table, it is ignored. If a name applies to a view, an ER_WRONG_OBJECT error occurs. Otherwise, an ER_NO_SUCH_TABLE error occurs.
InnoDB supports FOR EXPORT for tables that have their own .ibd file file (that is, tables created with the innodb_file_per_table setting enabled). InnoDB ensures when notified by the FOR EXPORT statement that any changes have been flushed to disk. This permits a binary copy of table contents to be made while the FOR EXPORT statement is in effect because the .ibd file is transaction consistent and can be copied while the server is running. FOR EXPORT does not apply to InnoDB system tablespace files, or to InnoDB tables that have FULLTEXT indexes.
FLUSH TABLES ...FOR EXPORT is supported for partitioned InnoDB tables.
When notified by FOR EXPORT, InnoDB writes to disk certain kinds of data that is normally held in memory or in separate disk buffers outside the tablespace files. For each table, InnoDB also produces a file named table_name.cfg in the same database directory as the table. The .cfg file contains metadata needed to reimport the tablespace files later, into the same or different server.
When the FOR EXPORT statement completes, InnoDB will have flushed all dirty pages to the table data files. Any change buffer entries are merged prior to flushing. At this point, the tables are locked and quiescent: The tables are in a transactionally consistent state on disk and you can copy the .ibd tablespace files along with the corresponding .cfg files to get a consistent snapshot of those tables.
For the procedure to reimport the copied table data into a MySQL instance, see Section 14.6.3.7, “Copying Tablespaces to Another Instance”.
After you are done with the tables, use UNLOCK TABLES to release the locks, LOCK TABLES to release the locks and acquire other locks, or START TRANSACTION to release the locks and begin a new transaction.
While any of these statements is in effect within the session, attempts to use FLUSH TABLES ... FOR EXPORT produce an error:
FLUSH TABLES ... WITH READ LOCK
FLUSH TABLES ... FOR EXPORT
LOCK TABLES ... READ
LOCK TABLES ... WRITE
While FLUSH TABLES ... FOR EXPORT is in effect within the session, attempts to use any of these statements produce an error:
FLUSH TABLES WITH READ LOCK
FLUSH TABLES ... WITH READ LOCK
FLUSH TABLES ... FOR EXPORT
FLUSH TABLES tbl_name [, tbl_name] ... FOR EXPORT適用于InnoDB表。它確保已將指定表的更改刷新到磁盤,以便在服務(wù)器運(yùn)行時(shí)創(chuàng)建二進(jìn)制表副本。
聲明的作用如下:
a.它獲取指定表的共享元數(shù)據(jù)鎖。只要其他會(huì)話具有已修改這些表或?yàn)槠浔4姹礞i的活動(dòng)事務(wù),該語(yǔ)句就會(huì)阻塞。獲取鎖定后,該語(yǔ)句將阻止嘗試更新表的事務(wù),同時(shí)允許只讀操作繼續(xù)。
b.它檢查表的所有存儲(chǔ)引擎是否支持FOR EXPORT。如果沒(méi)有,則發(fā)生ER_ILLEGAL_HA錯(cuò)誤,并且語(yǔ)句失敗。
c.該語(yǔ)句通知存儲(chǔ)引擎的每個(gè)表以使表準(zhǔn)備好導(dǎo)出。存儲(chǔ)引擎必須確保將所有掛起的更改寫入磁盤。
d.該語(yǔ)句將會(huì)話置于鎖定表模式,以便在FOR EXPORT語(yǔ)句完成時(shí)不會(huì)釋放先前獲取的元數(shù)據(jù)鎖。
FLUSH TABLES ... FOR EXPORT語(yǔ)句要求您具有每個(gè)表的SELECT權(quán)限。 由于此語(yǔ)句獲取表鎖,因此除了使用任何FLUSH語(yǔ)句所需的RELOAD權(quán)限之外,還必須為每個(gè)表具有LOCK TABLES權(quán)限。
此語(yǔ)句僅適用于現(xiàn)有的基本(非TEMPORARY)表。 如果名稱引用基本表,則使用該基本表。 如果它引用TEMPORARY表,則忽略它。 如果名稱適用于視圖,則會(huì)發(fā)生ER_WRONG_OBJECT錯(cuò)誤。 否則,發(fā)生ER_NO_SUCH_TABLE錯(cuò)誤。
對(duì)于具有自己的.ibd文件文件的表(即,啟用了innodb_file_per_table設(shè)置創(chuàng)建的表),InnoDB支持FOR EXPORT。 InnoDB確保FOR EXPORT語(yǔ)句發(fā)出時(shí)任何更改都已刷新到磁盤。這允許在FOR EXPORT語(yǔ)句生效時(shí)生成表內(nèi)容的二進(jìn)制副本,因?yàn)?ibd文件是事務(wù)一致的,并且可以在服務(wù)器running時(shí)進(jìn)行復(fù)制。 FOR EXPORT不適用于InnoDB系統(tǒng)表空間文件,也不適用于具有FULLTEXT索引的InnoDB表。
FLUSH TABLES ... FOR EXPORT支持分區(qū)的InnoDB表。
當(dāng)FOR EXPORT通知時(shí),InnoDB會(huì)將數(shù)據(jù)寫入磁盤,這些數(shù)據(jù)通常保存在內(nèi)存中或表空間文件之外的單獨(dú)磁盤緩沖區(qū)中。對(duì)于每個(gè)表,InnoDB還在與表相同的數(shù)據(jù)庫(kù)目錄中生成名為table_name.cfg的文件。 .cfg文件包含稍后將表空間文件重新導(dǎo)入相同或不同服務(wù)器所需的元數(shù)據(jù)。
當(dāng)FOR EXPORT語(yǔ)句完成時(shí),InnoDB會(huì)將所有臟頁(yè)刷新到表數(shù)據(jù)文件。 在刷新之前合并任何更改緩沖區(qū)條目。 此時(shí),表已鎖定且處于靜止?fàn)顟B(tài):表在磁盤上處于事務(wù)一致狀態(tài),您可以將.ibd表空間文件與相應(yīng)的.cfg文件一起復(fù)制,以獲得這些表的一致快照。
有關(guān)將復(fù)制的表數(shù)據(jù)重新導(dǎo)入MySQL實(shí)例的過(guò)程,請(qǐng)參見(jiàn)第14.6.3.7節(jié)“將表空間復(fù)制到另一個(gè)實(shí)例”。
完成表后,使用UNLOCK TABLES釋放鎖,使用LOCK TABLES釋放鎖并獲取其他鎖,或使用START TRANSACTION釋放鎖并開始新事務(wù)。
如下語(yǔ)句中的任何一個(gè)在會(huì)話中都有效,但在這個(gè)會(huì)話中再執(zhí)行FLUSH TABLES ... FOR EXPORT會(huì)產(chǎn)生錯(cuò)誤:
(報(bào)錯(cuò)信息ERROR 1192 (HY000): Can't execute the given command because you have active locked tables or an active transaction,當(dāng)然在其他會(huì)話執(zhí)行不會(huì)報(bào)錯(cuò),但是會(huì)一直等待,等待這個(gè)會(huì)話釋放)
FLUSH TABLES ... WITH READ LOCK
FLUSH TABLES ... FOR EXPORT
LOCK TABLES ... READ
LOCK TABLES ... WRITE
雖然FLUSH TABLES ... FOR EXPORT在會(huì)話中生效,但在這個(gè)會(huì)話中再使用如下語(yǔ)句中的任何一個(gè)都會(huì)產(chǎn)生錯(cuò)誤:
(報(bào)錯(cuò)信息ERROR 1192 (HY000): Can't execute the given command because you have active locked tables or an active transaction,當(dāng)然在其他會(huì)話執(zhí)行不會(huì)報(bào)錯(cuò),但是會(huì)一直等待,等待這個(gè)會(huì)話釋放)
FLUSH TABLES WITH READ LOCK
FLUSH TABLES ... WITH READ LOCK
FLUSH TABLES ... FOR EXPORT
感謝各位的閱讀,以上就是“怎么理解mysql中FLUSH TABLES和FLUSH TABLES WITH READ LOCK”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)怎么理解mysql中FLUSH TABLES和FLUSH TABLES WITH READ LOCK這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!