今天发现网站不能正常访问,因而登录服务器查找问题。mysql
机智的我随手用命令:df -l 发现 硬盘爆满了,因而就知道问题所在了。sql
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二进制日志文件)数据库
1、删除mysql日志文件
第一步:登录进入mysql,并使用 show binary logs; 查看日志文件。apache
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;vim
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之外的日志文件。spa
删除后就能释放大部分空间。.net
2、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;