Mysql binlog日志文件过大的解决

作者:say8129 时间:2024-01-19 09:49:15 

磁盘突然报错使用率过大,排查原因,发现mysql的binlog文件占用过大

命令


ls -l -h

Mysql binlog日志文件过大的解决

mysql-binlog是MySQL数据库的二进制日志,用于记录用户对数据库操作的SQL语句((除了数据查询语句)信息。可以使用mysqlbin命令查看二进制日志的内容。

可以通过设置my.cof配置文件的方式限制binlog文件的输出。

1、相关binlog配置

vim /etc/my.cof


[mysqld]
expire_logs_days = 3
#设置binlog清理时间

max_binlog_size = 100m
#binlog每个日志文件大小

binlog_cache_size = 4m
#binlog缓存大小

max_binlog_cache_size = 512m
#最 * inlog缓存大小

重启mysql,看到只保留了前三天的日志

Mysql binlog日志文件过大的解决

2、binlog相关高级设置

2.1 改变binlog模式

binlog的模式也有三种:STATEMENT、ROW、MIXED 。下面对这三种格式分别加以说明:

STATMENT模式

基于SQL语句的复制(statement-based replication, SBR),每一条会修改数据的sql语句会记录到binlog中。

优点:不需要记录每一条SQL语句与每行的数据变化,这样子binlog的日志也会比较少,减少了磁盘IO,提高性能。

缺点:在某些情况下会导致master-slave中的数据不一致(如sleep()函数, last_insert_id(),以及user-defined functions(udf)等会出现问题)

ROW模式

不记录每一条SQL语句的上下文信息,仅需记录哪条数据被修改了,修改成了什么样子了。

优点:不会出现某些特定情况下的存储过程、或function、或trigger的调用和触发无法被正确复制的问题。

缺点:会产生大量的日志,尤其是alter table的时候会让日志暴涨。

MIXED模式

混合模式复制(mixed-based replication, MBR):以上两种模式的混合使用,一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog,MySQL会根据执行的SQL语句选择日志保存方式。
修改配置文件


[mysqld]
binlog_format = mixed
#设置日志格式

2.2 相关SQL操作binlog


show binary logs;                            
# 查看binlog现有详情

show variables like '%log%';            
# 查看log变量的相关配置

set global expire_logs_days = 3;    
# 设置binlog的保存时间

reset master;                                
# 重置所有的binlog,相当于删除所有的binlog,这个操作对主从集群影响非常大,因为主从赋值是基于binlog日志来实现的

PURGE {MASTER | BINARY} LOGS TO 'log_name'
PURGE {MASTER | BINARY} LOGS BEFORE 'date'
# 删除指定的日志或日期之前的日志索引中的所有二进制日志。MASTER和BINARY是同义词

PURGE MASTER LOGS TO 'binlog.000013';
#清除binlog.000013日志

PURGE MASTER LOGS BEFORE '2020-01-08 10:00:00';  
#清除2020-01-08 10:00:00前binlog日志

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

来源:https://blog.csdn.net/weixin_42170236/article/details/112468076

标签:Mysql,binlog,日志,过大
0
投稿

猜你喜欢

  • 详细分析vue表单数据的绑定

    2023-07-02 16:27:51
  • Python爬虫爬取博客实现可视化过程解析

    2023-12-16 08:58:33
  • JavaScript实现简单贪吃蛇效果

    2023-08-13 05:48:08
  • 4款Javascript放大镜特效脚本

    2009-10-14 20:46:00
  • django-allauth入门学习和使用详解

    2022-05-24 12:36:09
  • MySQL主从搭建(多主一从)的实现思路与步骤

    2024-01-18 01:14:02
  • MySQL中由load data语句引起死锁的解决案例

    2024-01-19 19:37:14
  • PaddleOCR 识别表情包文字示例详解

    2023-06-02 06:41:55
  • Pycharm 如何一键加引号的方法步骤

    2022-09-11 19:19:34
  • BootStrap学习笔记之nav导航栏和面包屑导航

    2023-08-16 12:33:22
  • Python中使用json.load()和json.loads()加载json数据的方法实例

    2021-12-15 20:12:31
  • Bootstrap select多选下拉框实现代码

    2023-09-15 12:44:55
  • 详解Python的字符串格式化

    2022-05-01 10:35:52
  • 一篇文章弄懂PHP和HTML的嵌套写法

    2023-06-20 04:51:22
  • Python快速生成随机密码超简单实现

    2022-08-07 19:26:09
  • Django中间件拦截未登录url实例详解

    2022-05-15 05:30:21
  • PHP addAttribute()函数讲解

    2023-06-06 09:03:45
  • 为什么不压缩 HTML

    2010-05-07 12:37:00
  • sql无效字符 执行sql语句报错解决方案

    2024-01-13 01:40:26
  • Python OpenCV读取显示视频的方法示例

    2023-07-02 16:13:42
  • asp之家 网络编程 m.aspxhome.com