Pixz (pronounced pixie) is a parallel, indexing version of xz
.
Repository: /~https://github.com/vasi/pixz
Downloads: /~https://github.com/vasi/pixz/releases
The existing XZ Utils provide great compression in the .xz
file format,
but they produce just one big block of compressed data. Pixz instead produces a collection of
smaller blocks which makes random access to the original data possible. This is especially useful
for large tarballs.
pixz
automatically indexes tarballs during compression (unless the-t
argument is used)pixz
supports parallel decompression, whichxz
does notpixz
defaults to using all available CPU cores, whilexz
defaults to using only one corepixz
provides-i
and-o
command line options to specify input and output filepixz
does not need the command line option-z
(or--compress
). Instead, it compresses by default, and decompresses if-d
is passed.pixz
uses different logic to decide whether to use stdin/stdout.pixz somefile
will always output to another file, whilepixz
with no filenames will always use stdin/stdout. There's no-c
argument to explicitly request stdout.- Some other flags mean different things for
pixz
andxz
, including-f
,-l
,-q
and-t
. Please read the manpages for more detail on these.
General help about the building process's configuration step can be acquired via:
./configure --help
- pthreads
- liblzma 4.999.9-beta-212 or later (from the xz distribution)
- libarchive 2.8 or later
- AsciiDoc to generate the man page
./configure
make
make install
You many need sudo
permissions to run make install
.
git clone /~https://github.com/vasi/pixz.git
cd pixz
./autogen.sh
./configure
make
make install
You many need sudo
permissions to run make install
.
Compress a single file (no tarball, just compression), multi-core:
pixz bar bar.xz
Decompress it, multi-core:
pixz -d bar.xz bar
Compress and index a tarball, multi-core:
pixz foo.tar foo.tpxz
Very quickly list the contents of the compressed tarball:
pixz -l foo.tpxz
Decompress the tarball, multi-core:
pixz -d foo.tpxz foo.tar
Very quickly extract a single file, multi-core, also verifies that contents match index:
pixz -x dir/file < foo.tpxz | tar x
Create a tarball using pixz for multi-core compression:
tar -Ipixz -cf foo.tpxz foo/
These are the same (also work for -x
, -d
and -l
as well):
pixz foo.tar foo.tpxz
pixz < foo.tar > foo.tpxz
pixz -i foo.tar -o foo.tpxz
Extract the files from foo.tpxz
into foo.tar
:
pixz -x -i foo.tpxz -o foo.tar file1 file2 ...
Compress to foo.tpxz
, removing the original:
pixz foo.tar
Extract to foo.tar
, removing the original:
pixz -d foo.tpxz
Faster, worse compression:
pixz -1 foo.tar
Better, slower compression:
pixz -9 foo.tar
Use exactly 2 threads:
pixz -p 2 foo.tar
Compress, but do not treat it as a tarball, i.e. do not index it:
pixz -t foo.tar
Decompress, but do not check that contents match index:
pixz -d -t foo.tpxz
List the xz blocks instead of files:
pixz -l -t foo.tpxz
For even more tuning flags, check the manual page:
man pixz
- about equally complex and efficient
- lzip format seems less-used
- version 1 is theoretically indexable, I think
- written in Python, much simpler
- more flexible, supports arbitrary compression programs
- uses streams instead of blocks, not indexable
- splits input and then combines output, much higher disk usage
- simpler code
- uses OpenMP instead of pthreads
- uses streams instead of blocks, not indexable
- uses temporary files and does not combine them until the whole file is compressed, high disk and memory usage
- not indexable
- appears slow
- bzip2 algorithm is non-ideal
- not indexable
- not parallel