出于某种原因,当我运行
mysqltuner时,我的
MySQL服务器中的所有InnoDB表都被列为碎片.我几小时前才安装了服务器(在OSX Lion上),它有一堆从批处理文件中导入的新数据.
我尝试将一个数据库中的所有表转换为MYISAM,确定碎片表的数量已经下降了.奇怪的是,只要我将这些表格转换回InnoDB,碎片表计数就会重新开始.这与我迄今为止的研究相反,这表明运行ALTER TABLE table_name ENGINE = INNODB;应该修复碎片.
经过一段谷歌搜索,我跑了:
SELECT table_schema, table_name, data_free/1024/1024 AS data_free_MB
FROM information_schema.tables
WHERE engine LIKE 'InnoDB' AND data_free > 0
据说列出了所有碎片表(它确实返回与碎片表计数的mysqltuner输出相同数量的结果).每个条目在data_free_MB列中具有完全相同的编号(当前为7.00000000).
这实际上是一个真正的问题还是mysqltuner做错了什么?如果是问题,我该如何解决?
编辑
我变得越来越怀疑我是一个白痴,7MB碎片是针对整个文件的,而不是每张桌子.任何人都可以确认是否会出现这种情况?