mysql的binlog占用大量磁盘空间的解决方法

海哥  金牌会员 | 2024-6-21 13:02:16 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 963|帖子 963|积分 2889

查看当前日志保存天数:

  1. mysql> show variables like '%expire_logs_days%';
  2. +------------------+-------+
  3. | Variable_name    | Value |
  4. +------------------+-------+
  5. | expire_logs_days | 0     |
  6. +------------------+-------+
  7. 1 row in set (0.08 sec)
复制代码
默认是0,也就是logs不逾期。
也可以使用 show variables like '%expire%' 查看是否有开启日志到期自动删除
  1. mysql> show variables like '%expire%';
  2. +--------------------------------+--------+
  3. | Variable_name                  | Value  |
  4. +--------------------------------+--------+
  5. | binlog_expire_logs_auto_purge  | ON     |
  6. | binlog_expire_logs_seconds     | 432000 |
  7. | disconnect_on_expired_password | ON     |
  8. | expire_logs_days               | 0      |
  9. +--------------------------------+--------+
  10. 4 rows in set (0.00 sec)
复制代码
设置BINLOG到期时间

暂时见效,无需重起mysql

如果数据库此时不便重启,可以设置全局的参数,使他暂时见效:
mysql> set global expire_logs_days=5;
设置了只保存5天BINLOG, 下次重启mysql这个参数默认会失败。
如果上面指令报错,则改为set global binlog_expire_logs_seconds=432000
  1. mysql> set global expire_logs_days=7;ERROR 3683 (HY000): The option expire_logs_days and binlog_expire_logs_seconds cannot be used together. Please use binlog_expire_logs_seconds to set the expire time (expire_logs_days is deprecated)mysql> set global binlog_expire_logs_seconds=432000;Query OK, 0 rows affected (0.00 sec)mysql> mysql> show variables like '%expire%';
  2. +--------------------------------+--------+
  3. | Variable_name                  | Value  |
  4. +--------------------------------+--------+
  5. | binlog_expire_logs_auto_purge  | ON     |
  6. | binlog_expire_logs_seconds     | 432000 |
  7. | disconnect_on_expired_password | ON     |
  8. | expire_logs_days               | 0      |
  9. +--------------------------------+--------+
  10. 4 rows in set (0.00 sec)
复制代码
写入设置文件,mysql重启依旧见效

如果要永世见效,需要在my.cnf中设置
vi /etc/my.cnf
追加内容:
binlog_expire_logs_seconds=432000

手动删除BINLOG

也可以先手动删除BINLOG (purge binary logs)
删除指定的日志
mysql> PURGE {MASTER | BINARY} LOGS TO 'log_name'
例:删除binlog.1000
mysql> PURGE MASTER LOGS TO 'binlog.1000';
或删除指定日期之前的日志索引中的全部二进制日志。
mysql> PURGE {MASTER | BINARY} LOGS BEFORE 'date'
例:删除2023-06-03 12:00:00前的文件
mysql> PURGE MASTER LOGS BEFORE '2023-06-03 12:00:00';
例:删除3天前的日志
mysql> PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 3 DAY);

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

海哥

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表