Rechercher dans le manuel MySQL
13.7.7.3 FLUSH Syntax
The FLUSH
statement has several
variant forms that clear or reload various internal caches,
flush tables, or acquire locks. To execute
FLUSH
, you must have the
RELOAD
privilege. Specific flush
options might require additional privileges, as described later.
It is not possible to issue
FLUSH
statements within stored
functions or triggers. However, you may use
FLUSH
in stored procedures, so
long as these are not called from stored functions or
triggers. See Section C.1, “Restrictions on Stored Programs”.
By default, the server writes
FLUSH
statements to the binary
log so that they replicate to replication slaves. To suppress
logging, specify the optional
NO_WRITE_TO_BINLOG
keyword or its alias
LOCAL
.
FLUSH LOGS
,
FLUSH BINARY LOGS
,
FLUSH TABLES WITH READ LOCK
(with or without a table list), and
FLUSH
TABLES
are not written to the binary log in any case
because they would cause problems if replicated to a slave.
tbl_name
... FOR
EXPORT
The FLUSH
statement causes an
implicit commit. See Section 13.3.3, “Statements That Cause an Implicit Commit”.
The mysqladmin utility provides a
command-line interface to some flush operations, using commands
such as flush-hosts
,
flush-logs
,
flush-privileges
,
flush-status
, and
flush-tables
. See
Section 4.5.2, “mysqladmin — Client for Administering a MySQL Server”.
Sending a SIGHUP
signal to the server causes
several flush operations to occur that are similar to various
forms of the FLUSH
statement. See
Section 5.1.16, “Server Response to Signals”.
The RESET
statement is similar to
FLUSH
. See
Section 13.7.7.6, “RESET Syntax”, for information about using the
RESET
statement with replication.
The following list describes the permitted
FLUSH
statement
flush_option
values. For descriptions
of FLUSH
TABLES
variants, see
FLUSH TABLES Syntax.
Closes and reopens any binary log file to which the server is writing. If binary logging is enabled, the sequence number of the binary log file is incremented by one relative to the previous file.
Closes and reopens any flushable logs for installed storage engines. This causes
InnoDB
to flush its logs to disk.Closes and reopens any error log file to which the server is writing.
Closes and reopens any general query log file to which the server is writing.
Empties the host cache and the Performance Schema
host_cache
table that exposes the cache contents, and unblocks any blocked hosts. See Section 8.12.4.2, “DNS Lookup Optimization and the Host Cache”.Flush the host cache if some of your hosts change IP address or if the error message
Host '
occurs for connections from legitimate hosts. (See Section B.4.2.5, “Host 'host_name' is blocked”.) When more thanhost_name
' is blockedmax_connect_errors
errors occur successively for a given host while connecting to the MySQL server, MySQL assumes that something is wrong and blocks the host from further connection requests. Flushing the host cache enables further connection attempts from the host. The default value ofmax_connect_errors
is 100. To avoid this error message, start the server withmax_connect_errors
set to a large value.Closes and reopens any log file to which the server is writing. If binary logging is enabled, the sequence number of the binary log file is incremented by one relative to the previous file. If relay logging is enabled, the sequence number of the relay log file is incremented by one relative to the previous file.
FLUSH LOGS
has no effect on tables used for the general query log or for the slow query log (see Section 5.4.1, “Selecting General Query Log and Slow Query Log Output Destinations”).Rereads the cost model tables so that the optimizer starts using the current cost estimates stored in them. The server writes a warning to the error log for any unrecognized entries. (For information about these tables, see Section 8.9.5, “The Optimizer Cost Model”.) This operation affects only sessions that begin subsequent to the flush. Existing sessions continue to use the cost estimates that were current when they began.
Reloads the privileges from the grant tables in the
mysql
system database, and clears the in-memory cache used by thecaching_sha2_password
authentication plugin.As part of this operation, the server reads the
global_grants
table containing dynamic privilege assignments and registers any unregistered privileges found there.The server caches information in memory as a result of
GRANT
,CREATE USER
,CREATE SERVER
, andINSTALL PLUGIN
statements. This memory is not released by the correspondingREVOKE
,DROP USER
,DROP SERVER
, andUNINSTALL PLUGIN
statements, so for a server that executes many instances of the statements that cause caching, there will be an increase in memory use. This cached memory can be freed withFLUSH PRIVILEGES
.FLUSH RELAY LOGS [FOR CHANNEL
channel
]Closes and reopens any relay log file to which the server is writing. If relay logging is enabled, the sequence number of the relay log file is incremented by one relative to the previous file.
The
FOR CHANNEL
clause enables you to name which replication channel the statement applies to. Executechannel
FLUSH RELAY LOGS FOR CHANNEL
to flush the relay log for a specific replication channel. If no channel is named and no extra replication channels exist, the statement applies to the default channel. If no channel is named and multiple replication channels exist, the statement applies to all replication channels. For more information, see Section 17.2.3, “Replication Channels”.channel
Closes and reopens any slow query log file to which the server is writing.
This option adds the session status from all active sessions to the global status variables, resets the status of all active sessions, and resets account, host, and user status values aggregated from disconnected sessions. See Section 26.12.14, “Performance Schema Status Variable Tables”. This information may be of use when debugging a query. See Section 1.7, “How to Report Bugs or Problems”.
Resets all per-hour user resources to zero. This enables clients that have reached their hourly connection, query, or update limits to resume activity immediately.
FLUSH USER_RESOURCES
does not apply to the limit on maximum simultaneous connections that is controlled by themax_user_connections
system variable. See Section 6.2.20, “Setting Account Resource Limits”.
FLUSH TABLES Syntax
FLUSH TABLES
flushes tables, and,
depending on the variant used, acquires locks. Any
TABLES
variant used in a
FLUSH
statement must be the only
option used. FLUSH
TABLE
is a synonym for FLUSH
TABLES
.
The descriptions here that indicate tables are flushed by
closing them apply differently for InnoDB
,
which flushes table contents to disk but leaves them open.
This still permits table files to be copied while the tables
are open, as long as other activity does not modify them.
Closes all open tables, forces all tables in use to be closed, and flushes the prepared statement cache. For information about prepared statement caching, see Section 8.10.3, “Caching of Prepared Statements and Stored Programs”.
FLUSH TABLES
is not permitted when there is an activeLOCK TABLES ... READ
. To flush and lock tables, useFLUSH TABLES
instead.tbl_name
... WITH READ LOCKFLUSH 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.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.FLUSH TABLES WITH READ LOCK
acquires a global read lock rather than table locks, so it is not subject to the same behavior asLOCK TABLES
andUNLOCK TABLES
with respect to table locking and implicit commits:UNLOCK TABLES
implicitly commits any active transaction only if any tables currently have been locked withLOCK TABLES
. The commit does not occur forUNLOCK TABLES
followingFLUSH 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 executedUNLOCK TABLES
. Beginning a transaction does not release a global read lock acquired withFLUSH TABLES WITH READ LOCK
.
FLUSH TABLES WITH READ LOCK
does not prevent the server from inserting rows into the log tables (see Section 5.4.1, “Selecting General Query Log and Slow Query Log Output Destinations”).FLUSH TABLES
tbl_name
[,tbl_name
] ... WITH READ LOCKThis 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 theRELOAD
privilege that is required to use anyFLUSH
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 aTEMPORARY
table, it is ignored. If a name applies to a view, anER_WRONG_OBJECT
error occurs. Otherwise, anER_NO_SUCH_TABLE
error occurs.Use
UNLOCK TABLES
to release the locks,LOCK TABLES
to release the locks and acquire other locks, orSTART 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 thatFLUSH TABLES
is not permitted when there is an activeLOCK TABLES ... READ
.This statement does not perform an implicit
UNLOCK TABLES
, so an error results if you use the statement while there is any activeLOCK 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.FLUSH TABLES
tbl_name
[,tbl_name
] ... FOR EXPORTThis
FLUSH TABLES
variant applies toInnoDB
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:
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.
It checks whether all storage engines for the tables support
FOR EXPORT
. If any do not, anER_ILLEGAL_HA
error occurs and the statement fails.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.
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 theSELECT
privilege for each table. Because this statement acquires table locks, you must also have theLOCK TABLES
privilege for each table, in addition to theRELOAD
privilege that is required to use anyFLUSH
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 aTEMPORARY
table, it is ignored. If a name applies to a view, anER_WRONG_OBJECT
error occurs. Otherwise, anER_NO_SUCH_TABLE
error occurs.InnoDB
supportsFOR EXPORT
for tables that have their own.ibd
file file (that is, tables created with theinnodb_file_per_table
setting enabled).InnoDB
ensures when notified by theFOR EXPORT
statement that any changes have been flushed to disk. This permits a binary copy of table contents to be made while theFOR 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 toInnoDB
system tablespace files, or toInnoDB
tables that haveFULLTEXT
indexes.FLUSH TABLES ...FOR EXPORT
is supported for partitionedInnoDB
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
in the same database directory as the table. Thetable_name
.cfg.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 15.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, orSTART 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 ... FOR EXPORT
While
FLUSH TABLES ... FOR EXPORT
is in effect within the session, attempts to use any of these statements produce an error:
Document created the 26/06/2006, last modified the 26/10/2018
Source of the printed document:https://www.gaudry.be/en/mysql-rf-flush.html
The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.
References
These references and links indicate documents consulted during the writing of this page, or which may provide additional information, but the authors of these sources can not be held responsible for the content of this page.
The author This site is solely responsible for the way in which the various concepts, and the freedoms that are taken with the reference works, are presented here. Remember that you must cross multiple source information to reduce the risk of errors.