mysql-bin日志清理,并设置expire_logs_days时间,mysql占用空间过大问题

本文主要是介绍mysql-bin日志清理,并设置expire_logs_days时间,mysql占用空间过大问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mysql-bin日志清理,并设置expire_logs_days时间,mysql占用空间过大问题

文章目录

  • 问题
  • 查看mysql配置参数
  • 解决
    • 全局修改参数
    • 清理日志规则
    • 手动清理
    • my.cnf
  • 外传

问题

最近发现生产环境的服务器磁盘空间吃紧,查下到底是哪里占用的空间比较大,最后发现,mysql占用空间蛮大的。

du -sh *64G docker_data
6.4G    ftpwww
35G jenkins
33G mysql_data
33G www

发现mysql占用的空间很大,具体看看哪些数据占用了空间

cd mysql_data
ls -hl -rw-r----- 1 mysql mysql 1.1G 47 2023 mysql-bin.000001
-rw-r----- 1 mysql mysql 1.1G 422 2023 mysql-bin.000002
-rw-r----- 1 mysql mysql 1.1G 57 2023 mysql-bin.000003
-rw-r----- 1 mysql mysql 1.1G 520 2023 mysql-bin.000004
-rw-r----- 1 mysql mysql 1.1G 62 2023 mysql-bin.000005
-rw-r----- 1 mysql mysql 1.1G 615 2023 mysql-bin.000006
-rw-r----- 1 mysql mysql 1.1G 628 2023 mysql-bin.000007
-rw-r----- 1 mysql mysql 1.1G 711 2023 mysql-bin.000008
-rw-r----- 1 mysql mysql 477M 717 19:51 mysql-bin.000009
-rw-r----- 1 mysql mysql 1.1G 731 17:04 mysql-bin.000010
-rw-r----- 1 mysql mysql 1.1G 814 00:53 mysql-bin.000011
-rw-r----- 1 mysql mysql 1.1G 826 18:10 mysql-bin.000012
-rw-r----- 1 mysql mysql 1.1G 98 20:23 mysql-bin.000013
-rw-r----- 1 mysql mysql 1.1G 921 22:34 mysql-bin.000014
-rw-r----- 1 mysql mysql 1.1G 105 00:00 mysql-bin.000015
-rw-r----- 1 mysql mysql 1.1G 1018 02:13 mysql-bin.000016
-rw-r----- 1 mysql mysql 1.1G 1031 02:55 mysql-bin.000017
-rw-r----- 1 mysql mysql 1.1G 1115 12:04 mysql-bin.000018
-rw-r----- 1 mysql mysql 1.1G 121 12:10 mysql-bin.000019
-rw-r----- 1 mysql mysql 451M 128 18:30 mysql-bin.000020
-rw-r----- 1 mysql mysql  177 1211 09:57 mysql-bin.000021
-rw-r----- 1 mysql mysql 1.1G 1225 07:22 mysql-bin.000022
-rw-r----- 1 mysql mysql 1.1G 17 22:24 mysql-bin.000023

发现mysql-bin占用了很大的空间

mysql-bin为操作的日志,用作DB的数据恢复使用

查看mysql配置参数

vi /etc/my.cnf

发现配置了mysql-bin,但是为什么一直在增加没有删除,估计,是没有配置日志的保留时间

登录mysql或者使用mysql连接工具

show variables like 'expire_logs_days';

发现配置的默认是0,代表一致保存

解决

全局修改参数

因为生产环境DB,不能重启,暂时配置全局

-- 保存30天的日志
set global expire_logs_days=30;
show variables like 'expire_logs_days';

清理日志规则

设置之后不会立即清除,触发条件是:binlog大小超过max_binlog_size (默认max_binlog_size=1G)手动执行flush logs重新启动时(MySQL将会new一个新文件用于记录binlog)

show variables like 'max_binlog_size';

可以配置后,不用手动清理,等着规则触发清理即可。

手动清理

mysql> flush logs;

如果binlog非常多,不要轻易设置改参数,有可能导致io争用,这时候可以使用purge命令予以清除:

将mysql-bin.000008之前的binlog清掉:

mysql>purge binary logs to ‘mysql-bin.000008’;
将指定时间之前的binlog清掉:
mysql>purge binary logs before ‘2023-12-12 23:59:59’;

my.cnf

全局修改只是当前有效,如果要永久有效,需要更改my.cnf配置,然后重启mysql

外传

😜 原创不易,如若本文能够帮助到您的同学
🎉 支持我:关注我+点赞👍+收藏⭐️
📝 留言:探讨问题,看到立马回复
💬 格言:己所不欲勿施于人 扬帆起航、游历人生、永不言弃!🔥

这篇关于mysql-bin日志清理,并设置expire_logs_days时间,mysql占用空间过大问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/597028

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja