文档章节

mysql 日志爆满,删除日志文件,定时清理日志

Sam_y
 Sam_y
发布于 2017/07/03 21:05
字数 638
阅读 1.7W
收藏 3

「深度学习福利」大神带你进阶工程师,立即查看>>>

今天发现网站不能正常访问,于是登陆服务器查找问题。

机智的我随手用命令:df -l 发现 硬盘爆满了,于是就知道问题所在了。

Filesystem     1K-blocks     Used Available Use% Mounted on
/dev/xvda1      20641404 16963004   16929876  100% /
tmpfs             960368        0    960368   0% /dev/shm
/dev/xvdb1      51599192  4845536  44132564  10% /home/sam/share

然后通过命令 du -sh * 一路检查,发现mysql的日志文件占据了大部分空间 , 整整27G,于是现在的任务就是清理mysql的日志文件(主要是清理.log文件和mysql-bin.00000X二进制日志文件)

一、删除mysql日志文件

第一步:登陆进入mysql,并使用 show binary logs; 查看日志文件。

mysql> show binary logs;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000001 | 234592362 |
| mysql-bin.000002 | 425234342 |
| mysql-bin.000003 | 425345345 |
| mysql-bin.000004 | 234234222 |
| mysql-bin.000005 | 425994852 |
+------------------+-----------+
1 row in set (0.00 sec)

第二步:查看正在使用的日志文件:show master status;

mysql> show master status;
+------------------+-----------+--------------+------------------+-------------------+
| File             | Position  | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+-----------+--------------+------------------+-------------------+
| mysql-bin.000005 | 425994852 |              |                  |                   |
+------------------+-----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

当前正在使用的日志文件是mysql-bin.000005,那么删除日志文件的时候应该排除掉该文件。

删除日志文件的命令:purge binary logs to 'mysql-bin.000005'; 

mysql> purge binary logs to 'mysql-bin.000005';

删除除mysql-bin.000005以外的日志文件。

删除后就能释放大部分空间。

 

二、mysql 定时清理日志文件

如果每次等到发现空间不足的时候才去手动删除日志文件,这种方式是很不理想的。

那么,我们就需要设置mysql,让它能自动清理日志文件。

编辑mysql的配置文件,设置expire_logs_days(mysql定时删除日志文件)

[root@sam ~]# vim /etc/my.cnf

在my.cnf中,添加或修改expire_logs_days的值 (这里设置的自动删除时间为10天, 默认为0不自动删除)

expire_logs_days=10

修改后,重启mysql就会生效。

但是,在生产环境中,重启mysql数据库往往会付出很高的代价。

于是,可以在不重启mysql的情况下,修改expire_logs_days值

如下:

    登陆到mysql,并输入一下命令。

mysql> show variables like '%log%';
mysql> set global expire_logs_days = 10;

设置完后,可以通过 show variables like '%log%'; 看到expire_logs_days的值已被修改成10。

注意:通过这种方式设置expire_logs_days虽然不需要重启mysql即可生效,但是该方式在重启mysql之后,值会被恢复。

于是,建议通过mysql命令设置expire_logs_days的同时,也修改/etc/my.cnf下的expire_logs_days=10配置,这样在下次重启mysql的时候,expire_logs_days也一样是10;

Sam_y
粉丝 26
博文 41
码字总数 27998
作品 0
广州
程序员
私信 提问
加载中
请先登录后再评论。
访问安全控制解决方案

本文是《轻量级 Java Web 框架架构设计》的系列博文。 今天想和大家简单的分享一下,在 Smart 中是如何做到访问安全控制的。也就是说,当没有登录或 Session 过期时所做的操作,会自动退回到...

黄勇
2013/11/03
3.6K
8
用vertx实现高吞吐量的站点计数器

工具:vertx,redis,mongodb,log4j 源代码地址:https://github.com/jianglibo/visitrank 先看架构图: 如果你不熟悉vertx,请先google一下。我这里将vertx当作一个容器,上面所有的圆圈要...

jianglibo
2014/04/03
4.3K
3
我的架构演化笔记 功能1: 基本的用户注册

“咚咚”,一阵急促的敲门声, 我从睡梦中惊醒,我靠,这才几点,谁这么早, 开门一看,原来我的小表弟放暑假了,来南京玩,顺便说跟我后面学习一个网站是怎么做出来的。 于是有了下面的一段...

强子哥哥
2014/05/31
976
3
5分钟 maven3 快速入门指南

前提条件 你首先需要了解如何在电脑上安装软件。如果你不知道如何做到这一点,请询问你办公室,学校里的人,或花钱找人来解释这个给你。 不建议给Maven的服务邮箱来发邮件寻求支持。 安装Mav...

fanl1982
2014/01/23
1.2W
7
数据库代码辅助工具--MaoCaiJun.Database

MaoCaiJun.DataBase 是一个用于 Microsoft Visual Studio 的数据库代码生成组件。它是基于 xml 文件的代码创建工具,支持sql2000,sql2005,sql2008,access, SQLite MaoCaiJun.Database 数据库...

mccj
2013/02/06
2.5K
1

没有更多内容

加载失败,请刷新页面

加载更多

神奇“耳机”能刺激大脑神经,改善记忆力,外语学习能力提升13%

     大数据文摘出品   来源:inverse   编译:zeroInfinity   我们知道一句俗语叫做老狗难学新把戏。的确,多数成年人都会有这种感觉,学习新技能的能力远不如儿童,而这在语言学...

osc_l8yszczz
23分钟前
0
0
一周AI最火论文 | 使用图形界面就能搭建的强化学习模型

     大数据文摘出品   作者:Christopher Dossman   编译:李雷、Luna、云舟   呜啦啦啦啦啦啦啦大家好,本周的AI Scholar Weekly栏目又和大家见面啦!   AI ScholarWeekly是A...

osc_7slii3nj
25分钟前
0
0
女租户被偷拍4000条卧室视频,AI能发现“隐藏摄像头”吗?

     大数据文摘出品   作者:刘俊寰   你租的房子安全吗?   7月下旬,太原租客在房间发现多个隐蔽摄像头一事引起了多方关注。   根据澎湃新闻报道,一位女性租客租房中发现了多...

osc_zriqiio6
26分钟前
0
0
“别人”的毕设:造了个车!拆装驾驶一步到位,设计建模自行完成

     大数据文摘出品   作者:刘俊寰   疫情期间在家闭关能做点啥?看了几本书、补了几部美剧?   “别人家的孩子”利用这段时间,在家造出了一辆车!   你没听错,这是辆能上路...

osc_4eht81t7
28分钟前
14
0
“结婚”仍是应对竞争的优选,但斗鱼虎牙还要解决一个根本问题 - 知乎

作者|罗大肥 编辑|李春晖 百亿美元市值的中国新游戏直播巨头即将诞生,但人们远不像当初那样兴奋了。快抖B在侧,腾讯的“催婚”与其说是进攻,不如说是防守——两个人生活比单身省钱,父母也...

osc_2axit9df
30分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部