免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 7067 | 回复: 7
打印 上一主题 下一主题

mysql tuncate 空间未释放 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-08-28 14:22 |只看该作者 |倒序浏览
本帖最后由 a.a 于 2013-08-28 16:15 编辑

MySQL数据库里面的一张表比较大,占用的很多的空间。对它进行备份之后进行tuncate操作,但是truncate操作结束磁盘的空间并没有释放?
是需要重新启动一下数据库吗?

重新了启动数据库,但是空间仍未释放。
-------------------------------------
查询下资料原来innode引擎不会自动对其使用的空间进行收缩,需要借助optimize 来进行其内部存储结构的重新组织,释放相关的空间。

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每月发帖之星
日期:2015-09-11 19:30:52IT运维版块每周发帖之星
日期:2015-09-11 19:20:31IT运维版块每日发帖之星
日期:2015-08-26 06:20:00每日论坛发贴之星
日期:2015-08-20 06:20:00IT运维版块每日发帖之星
日期:2015-08-20 06:20:002015年辞旧岁徽章
日期:2015-03-03 16:54:15金牛座
日期:2014-05-04 16:58:09双子座
日期:2013-12-17 16:44:37辰龙
日期:2013-11-22 15:20:59狮子座
日期:2013-11-18 22:55:08射手座
日期:2013-11-12 10:54:26
2 [报告]
发表于 2013-08-28 20:45 |只看该作者
show full processlists; 看下是否还有thread在读或者写这个表?

论坛徽章:
0
3 [报告]
发表于 2013-08-29 09:52 |只看该作者
本帖最后由 a.a 于 2013-08-29 10:48 编辑

回复 2# wenhq


    操作的时候数据库处于空闲状态,processlit 里面没有针对对于操作表的query,重启mysql进程也是一样的。因为表是truncate掉的,然后我再次了一个drop操作,就没有办法做optimize了,我想把表重建一下然后再使用optimze 看看有没有效果。
   
-----------------------
   刚才尝试了重建表然后optimize,也是没有效果的。
   MySQL官方给的解决方法是:导出数据,删除掉数据文件,将数据重新导入。

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
4 [报告]
发表于 2013-08-29 10:03 |只看该作者
innodb 是个麻烦事,如果你用了 5.0 以上版本,可以使用开启独立表空间的innodb引擎,然后删除数据的时候就会释放空间了(只是表数据空间),共享的文件空间也不会释放。
不过不释放也不怕,mysql逻辑上已经把那些删除的数据的空间腾出来了,新加数据的时候会写在里面的,这时候你会看到空间的增长就不那么快了。

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
5 [报告]
发表于 2013-08-29 10:03 |只看该作者
innodb 是个麻烦事,如果你用了 5.0 以上版本,可以使用开启独立表空间的innodb引擎,然后删除数据的时候就会释放空间了(只是表数据空间),共享的文件空间也不会释放。
不过不释放也不怕,mysql逻辑上已经把那些删除的数据的空间腾出来了,新加数据的时候会写在里面的,这时候你会看到空间的增长就不那么快了。

论坛徽章:
0
6 [报告]
发表于 2013-08-29 10:52 |只看该作者
回复 4# seesea2517


     lz说的是innodb_file_per_table这个参数吧。好消息是在>5.6.6的版本中已经默认开启了。

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
7 [报告]
发表于 2013-08-29 14:15 |只看该作者
回复 6# a.a


我是 ls,你才是 lz。哈哈。

论坛徽章:
0
8 [报告]
发表于 2013-08-29 21:47 |只看该作者
中秋了,送点福利给哥们,一套Mysql优化的经典教程:http://t.cn/zQSXkUL
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP