MySQL清理binlog日志文件命令详解

 更新时间:2025年05月28日 08:40:06   作者:学亮编程手记  
这篇文章主要介绍了MySQL清理binlog日志文件命令方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

MySQL清理binlog日志文件命令

在这里插入图片描述

如果你担心旧的binlog文件会占用大量磁盘空间,可以在设置完成后清理旧的binlog文件:

删除旧的binlog文件

sudo rm /path/to/your/mysqllogs/mysql-bin.*

强制清除binlog文件

PURGE BINARY LOGS BEFORE '2024-09-19 00:00:00';
FLUSH BINARY LOGS;

Binlog日志清理问题

近期发现测试环境的Mysql数据库一直磁盘爆满,查看数据目录发现binlog日志很多很大,特记录处理过程。

查看所有binlog日志

show binary logs;

3种处理方式

自动删除(永久配置)

cat /etc/my.cnf
expire_logs_days = 2		
#保留最近2天的binlog文件;expire_logs_days 为binlog过期时间,默认值为0,表示“永不过期”,重启数据库生效

临时生效:

show variables like 'expire_logs_days';
set global expire_logs_days=1;

设置之后不会立即清除,触发条件是:

  • 1)binlog大小超过 max_binlog_size
  • 2)手动执行flush logs
  • 3)重新启动时(MySQL 将会new一个新文件用于记录binlog)

手动删除(安全处理)

purge会更新mysql-bin.index中的条目,而直接删除的话,mysql-bin.index文件不会更新。mysql-bin.index的作用是加快查找binlog文件的速度

#清除MySQL-bin.010日志
PURGE MASTER LOGS TO 'MySQL-bin.010';

#清除2008-06-22 13:00:00前binlog日志
PURGE MASTER LOGS BEFORE '2008-06-22 13:00:00';

#清除3天前binlog日志BEFORE,变量的date自变量可以为'YYYY-MM-DD hh:mm:ss'格式。
PURGE MASTER LOGS BEFORE DATE_SUB( NOW(), INTERVAL 3 DAY);

RESET MASTER; #该命令将删除所有BINLOG日志

注:生产环境需要先备份数据后再执行删除操作

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 经测试最好用的mysql密码忘记的解决方法

    经测试最好用的mysql密码忘记的解决方法

    经测试最好用的mysql密码忘记的解决方法...
    2007-06-06
  • MySQL Semaphore wait has lasted使用详解

    MySQL Semaphore wait has lasted使用详解

    MySQL 5.7.19 Semaphore wait >600秒错误源于InnoDB线程等待信号量超时,常见于死锁、资源竞争或IO瓶颈,排查需检查长事务、高并发写入、磁盘性能及数据页损坏,建议升级至5.7或8.0版本以修复问题
    2025-07-07
  • mysql如何将查询结果内容进行转换

    mysql如何将查询结果内容进行转换

    文章介绍了如何在MySQL中使用CASE表达式对查询结果进行多分支判断,并分享了个人经验,希望对大家有所帮助
    2025-02-02
  • 一篇文章讲解清楚MySQL索引

    一篇文章讲解清楚MySQL索引

    这篇文章主要用一篇文章讲解清楚MySQL索引的相关资料,十分的细致全面,推荐给大家,需要的朋友可以参考下
    2022-10-10
  • MySQL Workbench基本使用详细介绍

    MySQL Workbench基本使用详细介绍

    MySQL Workbench 是一个强大的工具,它通过图形界面简化了许多复杂的数据库任务,使得数据库的设计、开发和管理变得更加高效和直观,本文给大家介绍MySQL Workbench基本使用,感兴趣的朋友跟随小编一起看看吧
    2025-09-09
  • MySQL中select...for update锁表

    MySQL中select...for update锁表

    select…for update在MySQL中,是一种悲观锁的用法,一般情况下,会锁住一行数据,但如果没有使用正确的话,也会把整张表锁住,本文就来介绍一下,感兴趣的可以了解一下
    2023-10-10
  • MySQL触发器自动智能化的数据维护

    MySQL触发器自动智能化的数据维护

    这篇文章主要介绍了MySQL触发器自动智能化的数据维护,触发器,就是一种特殊的存储过程。触发器和存储过程一样是一个能够完成特定功能、存储在数据库服务器上的SQL片段
    2022-07-07
  • MySQL常用判断函数小结

    MySQL常用判断函数小结

    本文带大家一起来看一看MySQL中都有哪些常用的控制流函数,以及控制流函数的使用场景都有哪些,非常具有实用价值,需要的朋友可以参考下
    2023-05-05
  • Ubuntu 18.04配置mysql以及配置远程连接的步骤

    Ubuntu 18.04配置mysql以及配置远程连接的步骤

    这篇文章主要给大家介绍了关于Ubuntu 18.04配置mysql以及配置远程连接的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • MySQL从命令行导入SQL脚本时出现中文乱码的解决方法

    MySQL从命令行导入SQL脚本时出现中文乱码的解决方法

    这篇文章主要介绍了MySQL从命令行导入SQL脚本时出现中文乱码的解决方法,分析了中文乱码出现的原因并给出了两种解决方法供大家参考,需要的朋友可以参考下
    2016-09-09

最新评论