对于DB Server 来说,删除大表来说是很棘手的。删除大表的话,可以对原有表的.ibd文件建立硬链接。当多个文件名指向同一个Node时,删除任何一个文件名都很快,因为直连的物理文件没有删除只是删除了一个指针而已。当Node引用数为1的时候,删除文件需要把文件相关的所有数据块都删除。 今天我们只讨论,如果我们利用了以上方法建立了硬链接文件,那么删除该大文件的时候,如何避免IO hang呢? 答案是 coreutils 工具集中的 truncate 工具 truncate 收缩或扩展文件至指定大小 语法: truncate option ... file ... 如果文件不存在的话会被创建。 如果一个文件的size比指定的size大,则该文件会被截断丢是一部分数据,如果size比指定的小,那么他会0字节填充。 option: -c --no-create 如果没有该文件的话也不会创建 -o --io-blocks 对于文件的size大小以I/O block来对待 -r rfile --reference=file Base the size of each file on the size of rfile -s size --size=size 根据下面的选项,调整文件的大小 ‘KB’ => 1000 (KiloBytes) ‘K’ => 1024 (KibiBytes) ‘MB’ => 1000*1000 (MegaBytes) ‘M’ => 1024*1024 (MebiBytes) ‘GB’ => 1000*1000*1000 (GigaBytes) ‘G’ => 1024*1024*1024 (GibiBytes) 或者是 T P E Z这样的单位 根据下面的符号,根据他们本身的size来调整大小 + 扩展 - 缩小 < 至多 > 至少 / 向下舍入的倍数 % 向上的倍数 简单举例: touch abc truncate -s +1KB abc truncate -s +1KB abc ll abc -rwxrwxrwx 1 root root 2000 11月 28 05:31 abc
新闻热点
疑难解答