mysql删除binlog日志及日志恢复数据

WBOY
リリース: 2016-06-07 16:39:35
オリジナル
1079 人が閲覧しました

基本上大家装mysql,都会开启binlog功能,开启这个功能的好处是,日后方便恢复数据,而坏处是日志文件增长速度快,很快占会占满磁盘空间。 所以我们要定期或手工来删除过大的日志文件。 删除日志文件的方法大概有如下几中: 一、 设置日志保留时长 expire_lo

基本上大家装mysql,都会开启binlog功能,开启这个功能的好处是,日后方便恢复数据,而坏处是日志文件增长速度快,很快占会占满磁盘空间。
所以我们要定期或手工来删除过大的日志文件。
删除日志文件的方法大概有如下几中:

一、设置日志保留时长expire_logs_days自动删除

#查看当前日志保存天数:show?variables?like?’%expire_logs_days’;;#这个默认是0,也就是logs不过期,可通过设置全局的参数,使他临时生效:set?global expire_logs_days=7;#设置了只保留7BINLOG, 下次重启mysql这个参数默认会失败,所以需在my.cnf中设置expire_logs_days?=7

二、手动删除BINLOG?(purge?binary?logs)

其它:

#用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件

PURGE?{MASTER?|?BINARY}?LOGS?TO?”log_name”

PURGE?{MASTER?|?BINARY}?LOGS?BEFORE?”date”#例如:

PURGE?MASTER?LOGS?TO?”mysql-bin.010′;PURGE?MASTER?LOGS?BEFORE?”2008-06-2213:00:00′;

PURGE?MASTER?LOGS?BEFORE?DATE_SUB(?NOW(),?INTERVAL?3?DAY);

#查看当前日志文件列表:show?binary?logs;

使用binlog日志的目的是为了方便恢复数据,所以我们不光要会删除,还要会用日志来恢复数据。

使用binlog恢复数据:

使用mysqlbinlog命令恢复日志

mysqlbinlog?-d?test?/root/mysql/mysql-bin.000001|mysql-uroot?-ppassword

※附录

#1、关于mysqlbinlogmysql?5.0上的使用方法,可以参考:官方资料#2、如果不知道log-bin存放的文件位置,可以使用下面的命令查看:mysql-uroot?-ppassword?-e?’SHOW?BINLOG?EVENTS?\G’#3、当只是需要恢复部分记录的时候,你可以使用时间点或位置点来定位,例如:mysqlbinlog?–start-date=”2005-04-20?9:01:00″–stop-date=”2005-04-20?10:00:01″/var/log/mysql/bin.123456|mysql-uroot?-ppassword

#意思是恢复420日早上9点到10点这一段时间的数据。mysqlbinlog?–start-position=”368301″–stop-position=”368312″/var/log/mysql/bin.123456|mysql-uroot?-pmypwd

#意思是重做368301368312位置点之间的操作。(位置点可以就是用mysqlbinlog看到的at?xxx节点)mysqlbinlog?–start-date=”2005-04-20?9:55:00″–stop-date=”2005-04-20?10:05:00″/var/log/mysql/bin.123456?>/tmp/mysql_restore.sql

#同样的,如果我们只是想查看某段时间的操作,直接把它导到一个文件即可。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート