对于DB Server 来说,删除大表来说是很棘手的。

   删除大表的话,可以对原有表的.ibd文件建立硬链接。当多个文件名指向同一个Node时,删除任何一个文件名都很快,因为直连的物理文件没有删除只是删除了一个指针而已。当Node引用数为1的时候,删除文件需要把文件相关的所有数据块都删除。

具体参考:http://www.mysqlops.com/2011/05/18/mysql%E5%88%A0%E9%99%A4%E5%A4%A7%E8%A1%A8%E6%9B%B4%E5%BF%AB%E7%9A%84drop-table%E5%8A%9E%E6%B3%95.html

   今天我们只讨论,如果我们利用了以上方法建立了硬链接文件,那么删除该大文件的时候,如何避免IO hang呢?

   答案是 coreutils 工具集中的 truncate 工具

   wget http://ftp.gnu.org/gnu/coreutils/coreutils-8.9.tar.gz

     tar -zxvf coreutils-8.9.tar.gz
     cd coreutils-8.9
     ./configure
     make
     sudo cp src/truncate /usr/bin/ 
   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

   欢迎各位讨论!