0

0

如何配置mysql日志保留策略_mysql日志保留设置说明

P粉602998670

P粉602998670

发布时间:2026-01-05 12:41:04

|

792人浏览过

|

来源于php中文网

原创

MySQL日志保留策略通过配置binlog、error log、slow log和general log的自动清理机制实现,核心是设置过期时间或大小上限;binlog推荐用binlog_expire_logs_seconds(8.0.23+)或expire_logs_days(旧版)控制天数,error log依赖logrotate轮转并发送USR1信号,slow log和general log建议按需开启并定期归档,同时需监控日志大小防磁盘占满。

如何配置mysql日志保留策略_mysql日志保留设置说明

MySQL 日志保留策略主要通过配置二进制日志(binlog)、错误日志(error log)、慢查询日志(slow query log)和通用查询日志(general log)的自动清理机制来实现。核心控制方式是设置过期时间或文件大小上限,避免磁盘被日志占满。

二进制日志(binlog)保留天数控制

binlog 是主从复制和数据恢复的关键,但长期积累会占用大量空间。推荐用 expire_logs_days 参数设定自动删除天数(MySQL 8.0.23 起已弃用,建议改用 binlog_expire_logs_seconds)。

  • MySQL 5.7 / 8.0.22 及以前:在 my.cnf 的 [mysqld] 段中添加:
    expire_logs_days = 7(保留最近 7 天的 binlog)
  • MySQL 8.0.23+:使用更精确的秒级控制:
    binlog_expire_logs_seconds = 604800(即 7×24×3600 秒)
  • 生效后需重启 MySQL 或执行 SET PERSIST binlog_expire_logs_seconds = 604800;(动态生效,且持久化)
  • 手动清理可执行 PURGE BINARY LOGS BEFORE '2024-01-01 00:00:00'; 或按文件名清理

错误日志(error log)轮转与截断

MySQL 自身不直接管理 error log 的轮转,需依赖外部工具操作系统机制。

Flowith
Flowith

一款GPT4驱动的节点式 AI 创作工具

下载
  • 启用错误日志:确保 log_error 指向具体文件路径,如 log_error = /var/log/mysql/error.log
  • Linux 下常用 logrotate 配合:新建 /etc/logrotate.d/mysql,内容示例:
    /var/log/mysql/error.log {
      daily
      missingok
      rotate 30
      compress
      delaycompress
      notifempty
      create 640 mysql mysql
      sharedscripts
      postrotate
        if test -f /var/run/mysqld/mysqld.pid; then
          kill -USR1 `cat /var/run/mysqld/mysqld.pid`
        fi
      endscript
    }
  • USR1 信号会通知 MySQL 关闭并重新打开 error log 文件,完成无缝轮转

慢查询日志与通用查询日志的开关与归档

这两类日志 I/O 开销大,生产环境建议按需开启,并配合定期归档清理。

  • 开启慢查询日志:
    slow_query_log = ON
    slow_query_log_file = /var/log/mysql/slow.log
    long_query_time = 2
    (记录超过 2 秒的查询)
  • 通用查询日志默认关闭,如需调试可临时启用:
    general_log = ON
    general_log_file = /var/log/mysql/general.log
  • 不建议长期开启 general_log;slow_log 可结合 logrotate 定期压缩归档(配置方式同 error log)
  • MySQL 8.0+ 支持将 slow log 写入系统表 mysql.slow_log(需启用 log_output = TABLE),便于 SQL 查询分析,但需定期 TRUNCATE 清理

验证与监控日志清理效果

配置生效后,需定期检查实际保留情况,防止策略失效。

  • 查看当前 binlog 列表及最早时间:
    SHOW BINARY LOGS;SHOW MASTER STATUS;
  • 确认 error/slow log 文件修改时间:
    ls -lt /var/log/mysql/*.log
  • 检查 MySQL 错误日志是否包含轮转失败提示(如权限不足、USR1 未响应)
  • 建议在监控系统(如 Prometheus + mysqld_exporter)中加入日志文件大小告警,阈值设为磁盘总量的 20%~30%

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1090

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

356

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

674

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

411

2024.04.29

漫蛙2入口地址合集
漫蛙2入口地址合集

本专题整合了漫蛙2入口汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.6万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 780人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号