在使用MySQL数据库时,有时候由于数据量增加或者磁盘空间限制,会导致数据库磁盘空间不足的问题。这会影响到数据库的正常运行,需要及时清理磁盘空间来解决问题。本文将介绍如何清理MySQL数据库的磁盘空间,并给出示例以帮助读者更好地理解。
1、查看磁盘空间占用
df -lh
2、linux 文件按大小排序,从大到小排序
du -sh ./*
3、找到mysql的数据目录,可以看到binlog文件占用空间较多,
cd /var/lib/mysql
du -sh ./*
4、手动删除bin日志文件
mysql -u root -p
# 查看正在使用的日志文件:show master status;
show master status;
# 当前正在使用的日志文件是binlog.000070,那么删除日志文件的时候应该排除掉该文件。删除日志文件的命令如下
purge binary logs to 'binlog.000070';
5、查看mysql 大表 占用磁盘,从大到小排序
select
table_schema as '数据库',
table_name as '表名',
table_rows as '记录数',
truncate(data_length/1024/1024/1024, 2) as '数据容量(GB)',
truncate(index_length/1024/1024/1024, 2) as '索引容量(GB)'
from information_schema.tables
-- where table_schema='test'
order by data_length desc, index_length desc;
6、针对无用大表我们进行清除即可。
truncate table;