关于DB Server 来说,删去大表来说是很扎手的。
删去大表的话,可以对原有表的.ibd文件树立硬链接。当多个文件名指向同一个Node时,删去任何一个文件名都很快,由于直连的物理文件没有删去仅仅删去了一个指针罢了。当Node引证数为1的时分,删去文件需要把文件相关的一切数据块都删去。
详细参阅:
今日咱们只评论,假如咱们利用了以上办法树立了硬链接文件,那么删去该大文件的时分,怎么防止IO hang呢?
答案是 coreutils 东西会集的 truncate 东西
wget
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