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

打印 上一主题 下一主题

主题 846|帖子 846|积分 2538

本日发现网站不能正常访问,于是登陆服务器查找问题。
机警的我随手用下令:df -l 发现 硬盘爆满了,于是就知道问题所在了。
  1. Filesystem     1K-blocks     Used Available Use% Mounted on/dev/xvda1      20641404 16963004   16929876  100% /
  2. 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; 查看日志文件。
  1. mysql -u root -p
复制代码

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;

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

傲渊山岳

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表