您好,欢迎访问一九零五行业门户网

MySQL Flush 操作_MySQL

----------------------------------------------------------------
如果您想要清除mysql使用的部分内部缓存,您应该使用flush语句。要执行flush,您必须拥有reload权限。
flush_optionhosts
用于清空主机缓存表。如果有的主机更改了ip号或如果您得到了错误信息host host_name is blocked,则您应该刷新主机表。当在连接到mysql服务器时,如果对于一个给定的主机,接连出现错误“多于max_connect_errors”,此时,mysql会假定出现了错误,并阻止主机后续的连接申请。刷新主机表允许主机尝试再次连接。请参见a.2.5节,“主机的host_name被屏蔽”。您可以使用max_connect_errors=999999999启动mysqld,以避免此错误信息。
des_key_file
用于在服务器启动时,从采用--des-key-file选项指定的文件重新载入des关键字。
logs
用于关闭并重新打开所有的日志文件。如果您已经指定了一个更新日志文件或一个二进制日志文件,同时没有扩展,则相对于前一个文件,日志文件的扩展号增加1。如果您在文件名称中使用了一个扩展,则mysql会关闭并重新打开日志文件。在unix中,当相mysqld服务器发送一个sighup信号时,也会如此(例外情况是部分mac os x 10.3版本。在这些版本中,mysqld忽略sighup和sigquit)。
如果服务器使用--log-error选项,则flush logs会导致错误日志被重命名(使用后缀-old),同时mysqld会创建一个新的空日志文件。如果没有给定--log-error选项,则不会进行重命名。
privileges
用于从mysql数据库中的授权表重新载入权限。
query cache
对查询缓存进行整理碎片,以更好得利用存储器。与reset query cache不同,本语句不会从缓存中取消任何查询。
status
用于把多数状态变量重新设置为零。只在当调试查询时,您才应该使用此项。请参见1.7.1.3节,“如何通报缺陷和问题”。
{table | tables} [tbl_name [, tbl_name] ...]
当没有表被命名时,关闭所有打开的表,并迫使所有正在使用的表关闭。这也会刷新查询缓存。此项含有一个或多个表名称,只刷新给定的表。和reset query cache语句一样,flush tables还会取消来自查询缓存的所有查询结果。
tables with read lock
对于所有带读取锁定的数据库,关闭所有打开的表,并锁定所有的表,直到您执行unlock tables为止。如果您拥有一个可以及时进行快照的文件系统,比如veritas,则这是进行备份的非常方便的方法。
user_resources
用于把所有每小时用户资源重新设置为零。这可以使已经达到了每小时连接、查询或更新限值的客户端立刻重新恢复活性。flush user_resources不适用于同时连接的最大限值。请参见13.5.1.3节,“grant和revoke语法”。
flush语句被写入二进制日志,除非使用了自选的no_write_to_binlog关键字(或其别名local)。 注释:在任何情况下,flush logs, flush master, flush slave和flush tables with read lock都不会被记入日志,因为如果它们被复制到一个从属服务器上,会导致出现问题。
您也可以使用flush-hosts, flush-logs, flush-privileges, flush-status或flush-tables命令访问含有mysqladmin应用程序的语句。
其它类似信息

推荐信息