mysql log binbin-log可以删除吗

7248人阅读
Linux(49)
DataBase(16)
想要恢愎数据库以前的资料,执行:由于数据量很多,查看起来很麻烦,光打开个文件就要闪半天,所以应该适当删除部分可不用的日志。并且如果使用的时间足够长的话,会把我的硬盘空间都给吃掉
1.登录系统,/usr/bin/mysql使用mysql查看日志
+----------------+-----------+
| Log_name&&&&&& | File_size |
+----------------+-----------+
| ablelee.000001 |
| ablelee.000002 |
| ablelee.000003 |
+----------------+-----------+
2.删除bin-log(删除ablelee.000003之前的而没有包含ablelee.000003)
mysql& purge binary logs to 'ablelee.000003';
Query OK, 0 rows affected (0.16 sec)
3.& 查询结果(现在只有一条记录了.)
mysql& show binlog events/G
*************************** 1. row ***************************
&& Log_name: ablelee.000003
&&&&&&& Pos: 4
&Event_type: Format_desc
& Server_id: 1
End_log_pos: 106
&&&&&& Info: Server ver: 5.1.26-rc-log, Binlog ver: 4
1 row in set (0.01 sec)
(ablelee.000001和ablelee.000002已被删除)
+----------------+-----------+
| Log_name&&&&&& | File_size |
+----------------+-----------+
| ablelee.000003 |&&&&&& 106 |
+----------------+-----------+
1 row in set (0.00 sec)
(删除的其它格式运用!)
 & PURGE {MASTER | BINARY} LOGS TO 'log_name'  PURGE {MASTER | BINARY} LOGS BEFORE 'date'  用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件
中的清单中被删除,这样被给定的日志成为第一个。  例如:  PURGE MASTER LOGS TO 'mysql-bin.010';  PURGE MASTER LOGS BEFORE ' 13:00:00';&&& 清除3天前的 binlog&&& PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 3 DAY);  BEFORE变量的date自变量可以为'YYYY-MM-DD hh:mm:ss'格式。MASTER和BINARY是同义词。  如果您有一个活性的从属服务器,该服务器当前正在读取您正在试图删除的日志之一,则本语句不会起作用,
而是会失败,并伴随一个错误。不过,如果从属服务器是休止的,并且您碰巧清理了其想要读取的日志之一,则从
属服务器启动后不能复制。当从属服务器正在复制时,本语句可以安全运行。您不需要停止它们。  要清理日志,需按照以下步骤:  1. 在每个从属服务器上,使用SHOW SLAVE STATUS来检查它正在读取哪个日志。  2. 使用SHOW MASTER LOGS获得主服务器上的一系列日志。  3. 在所有的从属服务器中判定最早的日志。这个是目标日志。如果所有的从属服务器是更新的,这是清单上的
最后一个日志。
  4. 制作您将要删除的所有日志的备份。(这个步骤是自选的,但是建议采用。)
  5. 清理所有的日志,但是不包括目标日志。
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:1921544次
积分:12125
积分:12125
排名:第1252名
原创:113篇
转载:153篇
评论:164条
(1)(1)(2)(1)(1)(13)(3)(4)(3)(7)(21)(12)(2)(3)(1)(5)(3)(10)(15)(8)(12)(11)(4)(10)(3)(15)(8)(8)(13)(6)(6)(9)(1)(8)(11)(26)(4)(2)
(window.slotbydup = window.slotbydup || []).push({
id: '4740881',
container: s,
size: '200,200',
display: 'inlay-fix'mysql的binlog安全删除
理论上,应该在配置文件/f中加上binlog过期时间的配置项,expire_logs_days =
但是如果没有加这一项,随着产生越来越多的binlog,磁盘被吃掉了不少。可以直接删除binlog文件,但是可以通过mysql提供的工具来删除更安全。因为purge会更新mysql-bin.index中的条目,而直接删除的话,mysql-bin.index文件不会更新。mysql-bin.index的作用是加快查找binlog文件的速度。
先help一下吧:
mysql& help purge
Name: 'PURGE MASTER LOGS'
Description:
PURGE {MASTER | BINARY} LOGS TO 'log_name'
PURGE {MASTER | BINARY} LOGS BEFORE 'date'
Deletes all the binary logs listed in the log index prior to
specified log or date. The logs also are removed from the list
in the log index file, so that the given log becomes the first.
This statement has no effect if the --log-bin option has not
PURGE MASTER LOGS TO 'mysql-bin.010';
PURGE MASTER LOGS BEFORE ' 22:46:26';
两种方法都可用。第一个是删除至某一个文件为止,第二个是删除到某个日期为止。
比如我们让它保留近3天的log,可以这样
PURGE MASTER LOGS BEFORE ' 00:00:00';
看下执行前后的文件数:
part2# ls mysql-bin.*|wc -l
执行purge:
mysql& PURGE MASTER LOGS BEFORE '
00:00:00';
Query OK, 0 rows affected (0.02 sec)
part2# ls mysql-bin.* | wc -l
可见把17号前的binlog全部删除了。
需要注意的是:最好到slave上面去看下当前同步到那个binlog文件了,用show slave
status查看。否则,master上删多了的话,就造成slave缺失日志文件而导致数据不一致了。
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。3063人阅读
mysql(8)
1:进入MYSQL的CLIENT输入
+------------------+------------+
| Log_name&&&&&&&& | File_size& |
+------------------+------------+
| mysql-bin.000001 |&&&&&&& 117 |
| mysql-bin.000002 |&
| mysql-bin.000003 |&
| mysql-bin.000004 |&&&& 411062 |
| mysql-bin.000005 |&
| mysql-bin.000006 |&&
| mysql-bin.000007 |&&&& 763257 |
| mysql-bin.000008 |&&
| mysql-bin.000009 |
| mysql-bin.000010 |&
+------------------+------------+
10 rows in set (0.00 sec)
然后看到BIN-LOG日志的列表
2.删除bin-log(删除mysql-bin.000018之前的所有二进制日志文件)
mysql& purge binary logs to 'mysql-bin.000005';
如果你的服务器硬盘不是足够的大,slave,master的bin-log会占用很大的磁盘。清除方案如下:
1. 从属服务器上,使用SHOW SLAVE STATUS来检查它正在读取哪个日志。
2. 在主服务器上SHOW MASTER LOGS或show binary logs获得主服务器上的一系列日志。
3然后根据slave的Relay_Master_Log_File通过PURGE 删除LOG。
设置MASTER的expire_logs_days
+------------------+------------+
| Log_name&&&&&&&& | File_size& |
+------------------+------------+
| mysql-bin.000001 |&&&&&&& 117 |
| mysql-bin.000002 |&
| mysql-bin.000003 |&
| mysql-bin.000004 |&&&& 411062 |
| mysql-bin.000005 |&
| mysql-bin.000006 |&&
| mysql-bin.000007 |&&&& 763257 |
| mysql-bin.000008 |&&
| mysql-bin.000009 |
| mysql-bin.000010 |&
+------------------+------------+
10 rows in set (0.00 sec)
mysql& set global& expire_logs_days=7;
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (2.16 sec)
+------------------+-----------+
| Log_name&&&&&&&& | File_size |
+------------------+-----------+
| mysql-bin.000010 |
| mysql-bin.000011 |&&&&& 6410 |
+------------------+-----------+
2 rows in set (0.00 sec)
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:161896次
积分:2022
积分:2022
排名:第19913名
原创:41篇
评论:23条
(1)(2)(2)(1)(1)(1)(1)(1)(1)(1)(3)(2)(1)(7)(1)(4)(1)(2)(1)(1)(1)(1)(2)(2)(1)(3)(1)(1)
(window.slotbydup = window.slotbydup || []).push({
id: '4740881',
container: s,
size: '200,200',
display: 'inlay-fix'清理MySQL的bin-log二进制日志 /瑞豪开源(RASHOST)
Leave a Comment
要发表评论,您必须先。
北京瑞豪开源科技有限公司
北京海淀区学院南路12号北师大科技园57号楼213
邮政编码:100082
公司电话:010-
夜间紧急电话:176
新浪微博:
腾讯微博:
投诉建议:

我要回帖

更多关于 mysql5.7 logbin 的文章

 

随机推荐