Mysql Flush语法
flush [local | no_write_to_binlog] flush_option [, flush_option] ...
清除mysql使用的内部缓存,使用flush语句,必须拥有reload权限。
flush_option
hosts
- 用于清空主机缓存表,如果有的主机更改了IP号或如果得到了错误信息 HOST host_name is blocked, 则应该刷新主机表。
- 当在连接mysql服务器时,如果对于一个给定的主机,接连出现错误“多于max_connect_errors”,此时mysql会假设出现了错误,并阻止主机后续的链接申请。刷新主机表允许主机尝试再次连接。
- 主机的host_name被屏蔽,可以使用 max_connect_errors=999999999启动mysqld,可以避免此错误信息
logs
- 用于关闭并重新打开所有的日志文件,如果已经指定了一个更新日志文件或一个二进制日志文件,同时没有扩展项,则相对于前一个日志文件,日志文件的扩展号加1。如果在文件名称中使用了一个扩展,则mysql会关闭并重新打开日志文件
- 如果服务器使用 –log-error 选项,则 flush logs会导致错误日志被重命名(使用-old),同时mysql会创建一个新的空日志文件。反之不会新建日志文件。
privileges
用于mysql数据库中的授权表重新载入权限
query cache
对查询缓存进行整理碎片,以更好得利用存储器。与reset query cache不同,本语句不会从缓存中取消任何查询
status
用于把多数状态变量重新设置为零,只有在调试查询时,才可以使用此项
{table | tables} [tbl_name [, tabl_name]..]
- 当没有表被命名时,关闭所有打开的表,并迫使所有正在使用的表关闭。这也会刷新查询缓存。
- 次项含有一个或多个表名称,只刷新给定的表。
- 跟reset query cache语句一样,flush tables还会取消来自查询缓存的所有查询结果。
Tables with read lock
- 对于所有带读取锁定的数据库,关闭所有打开的表,并锁定所有的表,直到执行unlock tables为止。
- 如果拥有一个可以及时进行快照的文件系统,比如veritas,则这是进行备份的非常方便的方法。
user_resources
用于把所有每小时用户资源重新设置为零。这可以使已经达到了每小时连接、查询或更新限制的客户卡立刻重新恢复活性。flush user_resources 不适用于同时连接的最大限制。
注意
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应用程序的语句。
本文链接:https://lg1024.com/post/mysql_flush.html,参与评论 »
--EOF--
发表于 2018-11-07 21:26:00。
本站使用「署名 4.0 国际」创作共享协议,转载请注明作者及原网址。更多说明 »
提醒:本文最后更新于 396 天前,文中所描述的信息可能已发生改变,请谨慎使用。
专题「数据库相关知识」的其它文章 »
- mysql 用户权限管理 (Nov 21, 2018)
- Redis 分布式锁 (Aug 19, 2018)
- Redis 持久化 (Aug 08, 2018)
- Redis基础知识 (Aug 04, 2018)
- 几款主流的NoSQL数据库介绍 (Jun 04, 2018)
- Mysql性能优化--Explain详解 (Jan 08, 2018)
- Mysql五个强大语句 (Jan 06, 2018)
- Mongodb备份、还原、导入、导出 (Dec 20, 2017)
Comments