对于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 
	欢迎各位讨论!




















