mysql⽇志满如何清理_mysql⽇志爆满,删除⽇志⽂件,定时
清理⽇志
今天发现⽹站不能正常访问,于是登陆服务器查问题。
机智的我随⼿⽤命令: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)
mysql存储文档第⼆步:查看正在使⽤的⽇志⽂件: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/myf
在myf中,添加或修改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/myf下的expire_logs_days=10配置,这样在下次重启mysql 的时候,expire_logs_days也⼀样是10;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。