当前位置:首页 > 短网址资讯 > 正文内容

MySQL大表删除解决方案

www.ft12.com8年前 (2017-07-16)短网址资讯1958

1. 表删除问题汇总

  1. mysql如何删除表

  2. 删除大表如何优化、解决

2. 删除表原理与优化

删除表原理上分为2部分:

  1. buffer pool页面清除过程。
    在删除表的时候,Innodb 会将文件在buffer pool中对应的页面清除。对于删除表的页面清除,只需要将页面从flash队列中删除即可,而不需要去做flush操作,减小对系统的冲击。
    (1) 问题1:如果buffer pool很大,或者是在buffer pool中有很多需要被flush的页面,那么此时遍历扫描页面时就会占用比较长的时间,导致其他事务在用到相应buffer pool实例时被阻塞,从而影响整个数据库性能。

    • 优化:涉及源码,优化困难

  2. 删除ibd磁盘文件的过程。
    (1)问题1:表文件过大,直接删除会瞬时占用大量IO,造成IO阻塞

    • 优化:使用硬链

    • 原理:一个磁盘上的文件,可以由多个文件系统的文件引用,这多个文件的完全相同的,都指向同一个磁盘上的文件,当我们删除任何一个文件的时候,都不会影响真实的文件,只是会将其引用数据减1,只有当被引用数目变为1的时候,再次删除文件,才会真正被删除。删除时,这两种情况的区别很明显,一个是在减少被引用数目,一个是真正做IO来删除它

    • 操作:

ln /data/mydata/my3306/testdb/table1.ibd     /data/mydata/my3306/testdb/table1.ibd.hdlk
ls -lh    /data/mydata/my3306/testdb 查看文件引用数(应该为2)

(2) 问题2:做完硬链,真正的大文件删除问题,直接rm 删除,会造成IO瞬时高峰

  • 优化:使用工具,多次少量的删除

  • 原理:利用系统文件的truncate,脚本工具为slowrm

3. slowrm

注:此工具作者为 “贾春生”,此处只分享~

3.1 需求

缓解大表删除带来的IO瞬间压力

3.2 slowrm功能

将大文件按照指定速度进行删除,降低IO瞬间压力

3.3 slowrm实现

3.3.1 背景描述

先简要介绍下slowrm工具开发的背景。
我们曾在《linux_mysql_DROP_TABLE操作步骤》中提到,对于大表的删除,应当先建立硬链,drop table后,再删除表数据文件。
对于大表的数据文件,可能会达到10G,也可以是100G级别,甚至更大。在linux下,这样的大文件在使用rm时,无疑会导致IO资源被强行占用,表现为硬盘的io_util基本上是100%左右,会对其它IO操作造成阻塞。更可怕的是,rm单个文件的过程是个原子过程,无法使用kill或kill -9来杀死rm进程,只能乖乖的等待它结束。

如果是在繁忙的线上服务所在的机器上做这样的删除操作,很可能会对线上服务产生影响。因此需要有一个平滑删除大文件的方案。而这样的方案最终是与数据库无关的,而是一个通用方案。

3.3.2 设计思路

对于删除大文件的操作,采用每次将文件截断一点,分多次截断,最终直至文件大小被截断为0。
如下面的过程示例:

block_size = 1024576bytes;
while file_size >=block_size
begin
ftruncate (file, new_size);
(其中(old_size -new_size = block_size)
sleep 0.05 seconds;
end
ftruncate(file, 0);

因为既然rm一个文件是不可中断的,那么我们就将删除过程打散,分多次删除一个,每次删除一点。幸好现在的linux提供了支持该思路的API,truncate/ftruncate函数,可以对文件截断至任意长度()。经过测试,发现每次截断一点,分多次截断,最终直至文件大小被截断为0,这样删除大文件需要更多的时间,但是对磁盘IO的影响却大大减小了。因此采用该思路是可行的。

3.4 slowrm使用

slowrm  [OPTIONS]  FILES
对删除文件的方式与rm类似。

3.4.1 选项及参数

该工具的使用主要涉及两个参数:
-b   #size
每次需要截断掉的文件大小,单位为字节,参数值需要是整数,默认值4096 * 256Bytes( = 1MB);
-s   #seconds
每两次截断操作之间的时间间隔,单位为秒,参数值可以为小数。这两个参数用以控制删除速度,及删除过程对磁盘IO的压力。默认值0.1 second
-h, —help
查看帮助信息。

直接输入slowrm,或输入slowrm –h或slowrm —help可以查看帮助。

3.4.2 删除速度

可以看到默认删除速度是: 4096 * 256Bytes / 0.1second= 10MB/s,被删除的文件每秒钟可以减少10MB。
用户可以通过上述两个参数来控制删除的速度以及对磁盘IO的压力。

3.5 slowrm 与 rm 对比


可见,一般情况下,还是使用rm删除即可。
在需要低IO负载删除大文件时,可以使用slowrm。
slowrm对于rm是起到一个补充的作用。

3.6 注意

3.6.1 删除文件类型

目前,该工具只支持删除具体常规文件,无法对目录进行递归删除,但可以支持对多个文件进行删除,如slowrm .logmysql.err.2014
也无法对软链接,文件等进行删除。

3.6.2 硬链的删除

如果slowrm要删除的文件的硬链接数目大于1,那么就会直接删除该硬链;
如果待删除的文件硬链数目等于1,那么会按照平滑删除的方式,逐步截断该文件。

3.7 测试使用

制造大文件


开始删除


大小情况


压力情况
rrqm/s   wrqm/s     r/s     w/s    rMB/s    wMB/s avgrq-sz avgqu-sz   await  svctm  %util

3.8 日常使用

  1. 开启一个screen
    screen -S slowrm_test

  2. 开始删除文件
    slowrm file
    或者指定速度,正常默认即可(10MB/s)


扫描二维码推送至手机访问。

版权声明:本文由短链接发布,如需转载请注明出处。

本文链接:https://www.ft12.com/article_291.html

标签: MYSQL短网址
分享给朋友:

相关文章

FT12短网址:新浪微博短网址架构的演进

FT12短网址:新浪微博短网址架构的演进

引言新浪微博短网址(Weibo)是一种通过关注机制分享简短实时信息的广播式社交网络平台。微博用户通过关注来订阅内容,在这种场景下,推荐系统可以很好地和订阅分发体系进行融合,相互促进。微博两个核心基础点:一是用户关系构建,二是内容传播,微博推...

从“微信朋友圈三天可见”,探讨一下我们该如何面对社交网络

为何交际网络的规划这么杂乱?  1  近来接二连三的发现,在许多兄弟的个人主页下面都显示了这么一句经典的话。  “ — 兄弟仅展现近来三天的兄弟圈 — ”  在其个人资料栏里面,微信还展现了其“个人相册”的小图截屏,好像在告诉你,你兄弟没有...

如何使营销短信效果最大化?FT12「短链接」统计功能来支招

营销短信可以用较低成本换来高转化率,同时可以达到精准营销的目的,因而广泛受到电商平台的追捧。 但短信链接有没有被点击,短信发出去后的效果如何?如何让营销短信变成用户喜爱的有价信息而非垃圾信息?如何评估营销短信转化率?FT12「短链...

低质量的社交不如高质量的独处

低质量的社交不如高质量的独处

来源:视觉志(QQ_shijuezhi)不知道你有没有过这样的感触:一群人狂欢时的孤独,有时会胜过一个人独处。与其浪费时间精力,去做一些无用的社交,倒不如学会如何与自己相处。独处,当然,是一个人。你要耐得住寂寞,专注自己正在做的事。如果是在...

“黄鳝门”琪琪最新视频 女主播的下限到底在哪?

“黄鳝门”琪琪最新视频 女主播的下限到底在哪?

还记得今年三月份轰动全国的“黄鳝门”事件吗?3月23日晚,一段“女主播博眼球秀下限,将黄鳝塞入下体”的直播视频截图突然在网络上疯传!力压国足在世界杯预选赛胜出的历史性突破,成为当日最热点事件。女主播琪琪和她的黄鳝一同登上热搜,成为了这场风暴...

FT12短网址对科大讯飞2017半年报及人工智能战略的解读

FT12短网址对科大讯飞2017半年报及人工智能战略的解读

[ FT12短网址资讯 ] 2017年8月10日,科大讯飞应邀在合肥举行投资者交流会。董事长刘庆峰、高级副总裁兼董秘江涛、财务总监张少兵对公司半年报及人工智能战略进行了详细解读,并现场回答了投资者及网友十分关注的问题。鄙人一直对科大讯飞这几...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。