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

相关文章

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2

Spring AI Alibaba接入大模型时的依赖问题小结

《SpringAIAlibaba接入大模型时的依赖问题小结》文章介绍了如何在pom.xml文件中配置SpringAIAlibaba依赖,并提供了一个示例pom.xml文件,同时,建议将Maven仓... 目录(一)pom.XML文件:(二)application.yml配置文件(一)pom.xml文件:首