WEB开发网
开发学院数据库MySQL MYSQL日志文件维护 阅读

MYSQL日志文件维护

 2006-04-07 10:45:45 来源:WEB开发网   
核心提示: 更新日志和LOAD DATA 语句通常,当服务器执行LOAD DATE 语句时,MYSQL日志文件维护(2),它只将该语句本身而不是被加载的行内容写到更新日志中,这意味着除非该数据文件仍然保持可访问,则该用户应只有RELOAD 权限,例如,否则使用更新日志的恢复操作将是不完整的,为了确保这

更新日志和LOAD DATA 语句

通常,当服务器执行LOAD DATE 语句时,它只将该语句本身而不是被加载的行内容写到更新日志中。这意味着除非该数据文件仍然保持可访问,否则使用更新日志的恢复操作将是不完整的。为了确保这一点的安全,除非数据库已经备份,否则不应该删除数据文件。

系统备份

更新日志对于数据库恢复并不是任何时候都好,如果一个磁盘崩溃导致您失去了更新日志的话,应确保您执行定期的文件系统备份。将更新日志写到与存储数据库不相同的磁盘中也是一个好主意。

例如,如果您每天都循环日志,并且想保持一周的日志,则应保留log.0 到l o g . 6。在下一个循环中,将通过令log.5 覆盖log.6 使其成为新的log.6 来终止l o g . 6。这样,您就可以保留许多日志而又避免了它们超过磁盘的限度。

日志循环频率和保持的旧日志数量将依赖于服务器的繁忙程度(活动的服务器产生更多的日志信息)以及您希望为旧日志投入多少磁盘空间。当循环常规日志时,可以用mysqla d - min flush-logs 命令告诉服务器关闭当前的日志文件并打开新的日志文件。

执行常规日志循环的脚本类似如下(可修改它来反映您的日志基名和数据目录的位置,或许还有希望保留的旧日志的数量):

最好从mysqladm 账号中运行此脚本以确保日志文件属于那个用户。如果在.my.cnf 选项文件中保留连接参数,您不需要在该脚本的mysqladmin 命令中指定任何参数。如果您不这样做的话可以建立一个受限用户,它除了发布刷新命令外什么也不做。然后可以以最小的风险在该脚本中放置这个用户的口令。如果想这样做,则该用户应只有RELOAD 权限。例如,要想调用用户flush 并分配一个口令f l us h pass,可使用下列GRANT 语句:
GRANT RELOAD ON *.* TO flush@localhost IDENTIFIEDBY "flushpass"

Tags:MYSQL 日志 文件

编辑录入:coldstar [复制链接] [打 印]
赞助商链接