Linux下常用的tar工具无法支持并行 压缩和解压,对于大量小文件的解压缩,可借助pigz工具实现多线程并行工作,实现更为高效的压缩和解压缩。
首先安装 pigz创建脚本 mypigz
#! /bin/bash
name=$1
dir=$2
function pin_thread2core()
{
ps -efT | grep pigz | grep -v "grep"
pid=$(ps -efT | grep pigz | grep -v "grep" | awk '{print $3}')
echo $pid
coreid=2
for val in $pid
do
echo "taskset -cp $coreid $val"
taskset -cp $coreid $val
((coreid++))
done
}
cmdline=`cat /proc/cmdline`
coremask=${cmdline#*isolated_cores=}
echo coremask: $coremask
if [ "$coremask"x = x ]; then
echo "Invalid coremask"
coremask=1-10
fi
if [ $# -ge 2 ];then
#压缩
echo "start compress"
time taskset -c $coremask tar cf - $dir | taskset -c $coremask pigz -6 -p 10 -k > $name.tar.gz &
pin_thread2core
else
#解压
echo "start decompress: $name"
time pigz -p 10 -d $name &
pin_thread2core
tarname=$(basename $name .gz)
wait
time taskset -c $coremask tar xf $tarname
fi
wait
#压缩
./mypigz 文件名 目录
#解压
./mypigz 压缩包名
The End.