当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 '2024-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则设置为过期的!可以根据实际情况来设置合适的值。
MySQL如何清理binlog日志
来源:这里教程网
时间:2026-03-01 18:32:46
作者:
编辑推荐:
- MySQL如何清理binlog日志03-01
- MySQL数据库的线程状态03-01
- MySQL数据库InnoDB的锁等待03-01
- MySQL的plugin安装03-01
- 好书推荐,硬核指南让MySQL不再“黑箱“03-01
- MySQL的大小写敏感03-01
- MySQL基础维护实操手册:从启停到备份恢复03-01
- MySQL-8.0里的双密码功能( 8.0.14)03-01
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- 好书推荐,硬核指南让MySQL不再“黑箱“
好书推荐,硬核指南让MySQL不再“黑箱“
26-03-01 - MySQL基础维护实操手册:从启停到备份恢复
MySQL基础维护实操手册:从启停到备份恢复
26-03-01 - 数据库数据恢复—Mysql数据库误删除全表数据的数据恢复案例
数据库数据恢复—Mysql数据库误删除全表数据的数据恢复案例
26-03-01 - MySQL 基线核查实录:标准化配置与命令验证全解析
MySQL 基线核查实录:标准化配置与命令验证全解析
26-03-01 - 别再用 MySQL Workbench 了,快试试 SQLark!
别再用 MySQL Workbench 了,快试试 SQLark!
26-03-01 - MySQL锁定位实践指南
MySQL锁定位实践指南
26-03-01 - MySQL 9.4.0 正式发布,支持 RHEL 10 和 Oracle Linux 10
- MySQL5.7并行复制演变之路
MySQL5.7并行复制演变之路
26-03-01 - AI生成数据库运维平台,支持数据库一键安装、一键备份、一键巡检!
AI生成数据库运维平台,支持数据库一键安装、一键备份、一键巡检!
26-03-01 - MySQL创新版9.4.0发布,这次真不是“挤牙膏”!
MySQL创新版9.4.0发布,这次真不是“挤牙膏”!
26-03-01
