应使用PURGE BINARY LOGS或设置binlog_expire_logs_seconds自动清理,禁用手动删除;误删index文件可FLUSH BINARY LOGS重建;慢日志可动态关闭后轮转,错误日志需信号重载;备份前须确认binlog未被过期清理且权限充足。MySQL 的 binlog 文件占满磁盘怎么办直接删 binlog 文件会破坏主从同步或导致恢复失败,必须用 MySQL 自己的命令清理。关键不是"删",而是"过期自动淘汰"或"安全截断"。SHOW BINARY LOGS 先看当前有哪些日志、大小和生成时间用 PURGE BINARY LOGS BEFORE '2024-05-01 00:00:00' 清理指定时间前的日志(注意时区,建议用 NOW() - INTERVAL 7 DAY)更稳妥的做法是设置 expire_logs_days = 7(MySQL 8.0.23+ 改为 binlog_expire_logs_seconds = 604800),让服务自动清理别手动 rm -f /var/lib/mysql/mysql-bin.* ------ MySQL 还在写,index 文件没更新,下次启动可能报错 Failed to open log file误删了 mysql-bin.index 怎么恢复这个文件记录所有 binlog 文件名,MySQL 启动和 PURGE 都依赖它。一旦丢失,SHOW BINARY LOGS 会返回空,甚至主从 IO 线程卡住。如果 MySQL 还在运行,立刻执行 FLUSH BINARY LOGS,它会重建 mysql-bin.index 并追加当前活跃日志名如果已崩溃重启失败,先确认 log_bin 是开启的(SELECT @@log_bin 返回 1),再手动重建 index 文件:把当前存在的 mysql-bin.0000* 文件名按顺序写进 mysql-bin.index,每行一个,路径要绝对准确别用 RESET MASTER ------ 它清空所有 binlog 并重置序列号,主从环境里等于直接断掉复制链路slow_query_log_file 和 error_log 能不能直接清空可以,但方式不同:慢日志支持运行时轮转,错误日志不支持原地清空,必须配合系统命令和 MySQL 指令协同操作。 知网AI智能写作 知网AI智能写作,写文档、写报告如此简单
相关推荐
Li emily5 小时前
解决了加密货币api多币种订阅时的数据乱序问题Dicky-_-zhang5 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进2301_781571425 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】养肥胖虎5 小时前
RAG学习笔记(3):区分数据库检索与RAG的使用场景asdzx675 小时前
使用 Python 为 PDF 添加页码 (详细教程)AI技术控6 小时前
《Transformers are Inherently Succinct》论文解读:从“能表达什么”到“多紧凑地表达”_ku_ku_6 小时前
数据库系统原理 · 数据库应用开发 · 自学总结No8g攻城狮6 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9山峰哥7 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘代码中介商7 小时前
Redis入门:5大数据类型全解析