MySQL--binlog日志手动删除与自动清理

原文网址:MySQL--binlog日志手动删除与自动清理-CSDN博客

简介

本文介绍如何MySQL的binlog日志如何手动删除与自动清理。

默认情况下,MySQL会生成binlog日志,在增删改操作时会往binlog写数据。通过binlog记录可以找到增删改日志,可以将数据恢复到某条日志对应的时间点,可以用于数据库被误删、被攻击时进行恢复。

问题描述

默认情况下,mysql会生成很多个binlog,占用很大的空间。

查询binlog的方法如下:

法1:用MySQL命令

bash 复制代码
SHOW BINARY LOGS

结果如下(下边最大已经到了1G多):

法2:到MySQL服务器查文件

到MySQL数据路径下,执行命令:ls -lh

解决方案

方案是:删除旧的binlog,只保留最近的binlog;修改binlog的过期时间(默认一直存活),比如:2天。

方案1. 手动删除binlog

使用MySQL提供的purge命令删除binlog。purge命令的定义如下:

法1:指定文件名

将BINLOG-FILE-NAME之前日期的(不包括自己本身)所有binlog文件清理掉。

bash 复制代码
PURGE {BINARY | MASTER} LOGS TO "BINLOG-FILE-NAME"

例如:

bash 复制代码
PURGE BINARY LOGS TO 'mysql-bin.000007';

法2:指定时间

将最后修改时间早于datetime-rxpr的binlog文件清理掉(不包括自己)。

bash 复制代码
PURGE {BINARY | MASTER} LOGS BEFORE "DATETIME-EXPR"

例如:

bash 复制代码
PURGE BINARY LOGS BEFORE '2015-11-29 00:00:00';

方案2. 修改binlog过期时间

binlog_expire_logs_seconds参数可以控制binlog过期秒数,过了指定时间的日志将被自动删除,可动态修改。

  1. 如果设置了非0值,则在mysqld启动和日志刷新时,可能执行清理超过定义时间的binlog file
  2. 默认值为2592000(30天)。

查看binlog_expire_logs_seconds的方法:

bash 复制代码
SHOW GLOBAL VARIABLES LIKE 'BINLOG_EXPIRE_LOGS_SECONDS';

结果如下图所示:

法1:修改配置文件(需重启MySQL)

修改配置文件:/etc/my.cnf,在[mysqld]节点中增加如下内容

bash 复制代码
# binlog过期时间设置为3天。默认为30天。
binlog_expire_logs_seconds=259200

法2:使用命令(不需重启MySQL)

bash 复制代码
SET GLOBAL BINLOG_EXPIRE_LOGS_SECONDS=259200;

如下图所示:

相关推荐
hiwb19 小时前
Docker 安装 MySQL,DBeaver 连接 MySQL
mysql·docker·容器
·云扬·19 小时前
从0到1理解分库分表:我踩过的坑与实战经验
运维·数据库·mysql
这是程序猿20 小时前
MySQL 索引一篇讲透:原理、分类、优化与面试总结
java·前端·mysql
snow@li21 小时前
数据库MySQL:常用语法 / MySQL 核心知识技能梳理
数据库·mysql
想唱rap21 小时前
TCP套接字编程
java·linux·网络·c++·tcp/ip·mysql·ubuntu
杨云龙UP21 小时前
Docker MySQL 5.7 全库备份到异地服务器实践记录_20260427
linux·运维·服务器·数据库·mysql·docker·容器
运维全栈笔记21 小时前
K8S部署MySQL主从复制实现高可用数据库
mysql·adb·云原生·容器·系统架构·kubernetes·kubelet
zxrhhm1 天前
MySQL 8.4 LTS 数据库巡检脚本
数据库·mysql
oldking呐呐1 天前
MySQL从入门到入土 -- 2.数据库基础
后端·mysql
Bert.Cai2 天前
MySQL TRIM()函数详解
数据库·mysql