[分享]mysql如何删除 bin log _MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2529 | 回复: 0   主题: [分享]mysql如何删除 bin log         下一篇 
justfriend
注册用户
等级:新兵
经验:61
发帖:62
精华:0
注册:2011-11-21
状态:离线
发送短消息息给justfriend 加好友    发送短消息息给justfriend 发消息
发表于: IP:您无权察看 2014-11-27 17:46:30 | [全部帖] [楼主帖] 楼主

当mysql 日志占用太大空间的时候,要考虑将日志删除

一 语法如下:

PURGE {MASTER | BINARY} LOGS TO 'log_name'
PURGE {MASTER | BINARY} LOGS BEFORE 'date'


用于删除在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个。

例如:

1 删除指定日志之前的bin log

PURGE MASTER LOGS TO 'mysql-bin.010';


1) 查看当前的log

mysql> show binary logs;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000001 |       126 |
| mysql-bin.000002 |  88416282 |
| mysql-bin.000003 | 198081520 |
| mysql-bin.000004 |      1358 |
| mysql-bin.000005 |       126 |
| mysql-bin.000006 |       126 |
| mysql-bin.000007 |       126 |
| mysql-bin.000008 |       315 |
| mysql-bin.000009 |       126 |
| mysql-bin.000010 |       126 |
| mysql-bin.000011 |       504 |
| mysql-bin.000012 |       107 |
| mysql-bin.000013 |       107 |
| mysql-bin.000014 |       107 |
| mysql-bin.000015 |       107 |
| mysql-bin.000016 |       521 |
| mysql-bin.000017 |       315 |
| mysql-bin.000018 |       958 |
+------------------+-----------+
18 rows in set (0.04 sec)


2) 删除mysql-bin.000010 之前的日志

mysql> purge binary logs to 'mysql-bin.000010';
Query OK, 0 rows affected (0.35 sec)
mysql> show binary logs;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000010 |       126 |
| mysql-bin.000011 |       504 |
| mysql-bin.000012 |       107 |
| mysql-bin.000013 |       107 |
| mysql-bin.000014 |       107 |
| mysql-bin.000015 |       107 |
| mysql-bin.000016 |       521 |
| mysql-bin.000017 |       315 |
| mysql-bin.000018 |       958 |
+------------------+-----------+
9 rows in set (0.00 sec)


3)显示第一个二进制日志: 

mysql> show binlog events;
+------------------+-----+-------------+-----------+-------------+---------------------------------------+
| Log_name         | Pos | Event_type  | Server_id | End_log_pos | Info                                  |
+------------------+-----+-------------+-----------+-------------+---------------------------------------+
| mysql-bin.000010 |   4 | Format_desc |         1 |         107 | Server ver: 5.5.18-log, Binlog ver: 4 |
| mysql-bin.000010 | 107 | Stop        |         1 |         126 |                                       |
+------------------+-----+-------------+-----------+-------------+---------------------------------------+
2 rows in set (0.01 sec)


2 删除指定日期之前的bin log

PURGE MASTER LOGS BEFORE '2011-12-05 13:00:00';


3 清除N天前的 binlog

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


BEFORE变量的date自变量可以为'YYYY-MM-DD hh:mm:ss'格式。MASTER和BINARY是同义词。

下面的语句可以清除 7 天前的binlog,

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


在contab设置定期每天凌晨3点删除7天前的binlog:

0 3 * * *  `mysql -uroot -e 'PURGE BINARY LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 7 DAY);'`


二 主从架构的日志删除

对于主从结构的mysql系统,slave服务器当前正在读取试图删除的日志之一,则删除语句失败,并且报错。不过,如果在slave服务器是停止运行期间清理了其未读取的日志之一,则slave服务器启动后不能复制。当slave服务器正在复制时,删除日志的语句可以安全运行,并不需要停止它们。

主从架构的可以按照以下步骤清理日志:

1. 在每个SLAVE服务器上,使用SHOW SLAVE STATUS来检查它正在读取的日志。

2. 使用SHOW MASTER LOGS获得主服务器上的已经归档的日志。

3. 在所有的slave服务器中判定最早的日志,既截至目标日志。如果所有的slave服务器是更新的,这是清单上的最后一个日志。

4. 备份将要删除的所有日志,防止意外!

5. 删除日志,但不包括目标日志。

三 相关参数:

  配置文件my.cnf的参数expire-logs-days 指定了日志过期的天数,比如
expire-logs-days  = 20 表示日志保留20,超过20则设置为过期的!可以根据实际情况来设置合适的值~~

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论