2010-06-19 18:45:39 +04:00
|
|
|
.Dd June 19, 2010
|
|
|
|
.Dt PIGZ 1
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm pigz ,
|
|
|
|
.Nm unpigz
|
|
|
|
.Nd compress or expand files
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm
|
|
|
|
.Op Fl 0..9cdfhiKkLlNnqRrTtz
|
|
|
|
.Op Fl b Ar blocksize
|
|
|
|
.Op Fl p Ar threads
|
|
|
|
.Op Fl S Ar suffix
|
|
|
|
.Op Ar
|
|
|
|
.Nm unpigz
|
|
|
|
.Op Fl cfhiKkLlNnqRrTtz
|
|
|
|
.Op Fl b Ar blocksize
|
|
|
|
.Op Fl p Ar threads
|
|
|
|
.Op Fl S Ar suffix
|
|
|
|
.Op Ar
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
.Nm
|
2010-06-17 10:05:09 +04:00
|
|
|
compresses using threads to make use of multiple processors and cores.
|
|
|
|
The input is broken up into 128 KB chunks with each compressed in parallel.
|
|
|
|
The individual check value for each chunk is also calculated in parallel.
|
|
|
|
The compressed data is written in order to the output, and a combined check
|
|
|
|
value is calculated from the individual check values.
|
2010-06-19 18:45:39 +04:00
|
|
|
.Pp
|
2010-06-17 10:05:09 +04:00
|
|
|
The compressed data format generated is in the gzip, zlib, or single-entry
|
|
|
|
zip format using the deflate compression method. The compression produces
|
|
|
|
partial raw deflate streams which are concatenated by a single write thread
|
|
|
|
and wrapped with the appropriate header and trailer, where the trailer
|
|
|
|
contains the combined check value.
|
2010-06-19 18:45:39 +04:00
|
|
|
.Pp
|
2010-06-17 10:05:09 +04:00
|
|
|
Each partial raw deflate stream is terminated by an empty stored block
|
2010-06-19 18:45:39 +04:00
|
|
|
(using the
|
|
|
|
.Dv Z_SYNC_FLUSH
|
|
|
|
option of
|
|
|
|
.Xr zlib 3 ) ,
|
|
|
|
in order to end that partial bit stream at a byte boundary.
|
|
|
|
That allows the partial streams to be concatenated simply as sequences
|
|
|
|
of bytes.
|
|
|
|
This adds a very small four to five byte overhead to the output for
|
|
|
|
each input chunk.
|
|
|
|
.Pp
|
2010-06-17 10:05:09 +04:00
|
|
|
The default input block size is 128K, but can be changed with the
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl b
|
|
|
|
option.
|
|
|
|
The number of compress threads is set by default to the number
|
|
|
|
of online processors, which can be changed using the
|
|
|
|
.Fl p
|
|
|
|
option.
|
|
|
|
Specifying
|
|
|
|
.Fl p Ar 1
|
2010-06-17 10:05:09 +04:00
|
|
|
avoids the use of threads entirely.
|
2010-06-19 18:45:39 +04:00
|
|
|
.Pp
|
2010-06-17 10:05:09 +04:00
|
|
|
The input blocks, while compressed independently, have the last 32K of the
|
|
|
|
previous block loaded as a preset dictionary to preserve the compression
|
2010-06-19 18:45:39 +04:00
|
|
|
effectiveness of deflating in a single thread.
|
|
|
|
This can be turned off using the
|
|
|
|
.Fl i
|
2010-06-17 10:05:09 +04:00
|
|
|
or
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl Fl independent
|
2010-06-17 10:05:09 +04:00
|
|
|
option, so that the blocks can be decompressed
|
|
|
|
independently for partial error recovery or for random access.
|
2010-06-19 18:45:39 +04:00
|
|
|
.Pp
|
2010-06-17 10:05:09 +04:00
|
|
|
Decompression can't be parallelized, at least not without specially prepared
|
2010-06-19 18:45:39 +04:00
|
|
|
deflate streams for that purpose.
|
|
|
|
As a result,
|
|
|
|
.Nm
|
|
|
|
uses a single thread (the main thread) for decompression, but will
|
|
|
|
create three other threads for reading, writing, and check
|
|
|
|
calculation, which can speed up decompression under some
|
|
|
|
circumstances.
|
|
|
|
Parallel decompression can be turned off by specifying one process
|
|
|
|
.Fl ( dp Ar 1
|
2010-06-17 10:05:09 +04:00
|
|
|
or
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl tp Ar 1 ) .
|
|
|
|
.Pp
|
2010-06-17 10:05:09 +04:00
|
|
|
Compressed files can be restored to their original form using
|
2010-06-19 18:45:39 +04:00
|
|
|
.Nm pigz Fl d
|
2010-06-17 10:05:09 +04:00
|
|
|
or
|
2010-06-19 18:45:39 +04:00
|
|
|
.Nm unpigz .
|
|
|
|
.Sh OPTIONS
|
|
|
|
.Bl -tag -width XXiXXXindependentXX
|
|
|
|
.It Fl #, Fl Fl fast, Fl Fl best
|
2010-06-17 10:05:09 +04:00
|
|
|
Regulate the speed of compression using the specified digit
|
2010-06-19 18:45:39 +04:00
|
|
|
.Ar # ,
|
2010-06-17 10:05:09 +04:00
|
|
|
where
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl 1
|
2010-06-17 10:05:09 +04:00
|
|
|
or
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl Fl fast
|
2010-06-17 10:05:09 +04:00
|
|
|
indicates the fastest compression method (less compression)
|
|
|
|
and
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl 9
|
2010-06-17 10:05:09 +04:00
|
|
|
or
|
2010-06-19 18:45:39 +04:00
|
|
|
.Fl Fl best
|
2010-06-17 10:05:09 +04:00
|
|
|
indicates the slowest compression method (best compression).
|
|
|
|
Level 0 is no compression.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl b, Fl Fl blocksize Ar mmm
|
|
|
|
Set compression block size to
|
|
|
|
.Ar mmm
|
|
|
|
K (default 128KiB).
|
|
|
|
.It Fl c, Fl Fl stdout, Fl Fl to-stdout
|
2010-06-17 10:05:09 +04:00
|
|
|
Write all processed output to stdout (won't delete).
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl d, Fl Fl decompress, Fl Fl uncompress
|
2010-06-17 10:05:09 +04:00
|
|
|
Decompress the compressed input.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl f, Fl Fl force
|
2010-06-17 10:05:09 +04:00
|
|
|
Force overwrite, compress .gz, links, and to terminal.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl h, Fl Fl help
|
2010-06-17 10:05:09 +04:00
|
|
|
Display a help screen and quit.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl i, Fl Fl independent
|
2010-06-17 10:05:09 +04:00
|
|
|
Compress blocks independently for damage recovery.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl K, Fl Fl zip
|
2010-06-17 10:05:09 +04:00
|
|
|
Compress to PKWare zip (.zip) single entry format.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl k, Fl Fl keep
|
|
|
|
Do not delete original file after processing.
|
|
|
|
.It Fl L, Fl Fl license
|
2010-06-17 10:05:09 +04:00
|
|
|
Display the
|
2010-06-19 18:45:39 +04:00
|
|
|
.Nm pigz
|
2010-06-17 10:05:09 +04:00
|
|
|
license and quit.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl l, Fl Fl list
|
|
|
|
List the contents of the compressed input.
|
|
|
|
.It Fl N, Fl Fl name
|
2010-06-17 10:05:09 +04:00
|
|
|
Store/restore file name and mod time in/from header.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl n, Fl Fl no-name
|
|
|
|
Do not store or restore file name in/from header.
|
|
|
|
.It Fl p, Fl Fl processes Ar n
|
2010-06-17 10:05:09 +04:00
|
|
|
Allow up to n processes (default is the number of online processors)
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl q, Fl Fl quiet, Fl Fl silent
|
2010-06-17 10:05:09 +04:00
|
|
|
Print no messages, even on error.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl r, Fl Fl recursive
|
2010-06-17 10:05:09 +04:00
|
|
|
Process the contents of all subdirectories.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl S, Fl Fl suffix Ar .sss
|
|
|
|
Use suffix
|
|
|
|
.Ar .sss
|
|
|
|
instead of
|
|
|
|
.Pa .gz
|
|
|
|
(for compression).
|
|
|
|
.It Fl T, Fl Fl no-time
|
2010-06-17 10:05:09 +04:00
|
|
|
Do not store or restore mod time in/from header.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl t, Fl Fl test
|
|
|
|
Test the integrity of the compressed input.
|
|
|
|
.It Fl V, Fl Fl version
|
2010-06-17 10:05:09 +04:00
|
|
|
Show the version of pigz.
|
2010-06-19 18:45:39 +04:00
|
|
|
.It Fl v, Fl Fl verbose
|
|
|
|
Provide more verbose output.
|
|
|
|
.It Fl z, Fl Fl zlib
|
|
|
|
Compress to zlib
|
|
|
|
.Pq Pa .zz
|
|
|
|
instead of gzip format.
|
|
|
|
.El
|
|
|
|
.Sh COPYRIGHT NOTICE
|
2010-06-17 10:05:09 +04:00
|
|
|
This software is provided 'as-is', without any express or implied
|
2010-06-19 18:45:39 +04:00
|
|
|
warranty.
|
|
|
|
In no event will the author be held liable for any damages
|
2010-06-17 10:05:09 +04:00
|
|
|
arising from the use of this software.
|
2010-06-19 18:45:39 +04:00
|
|
|
.Pp
|
|
|
|
Copyright (C) 2007, 2008, 2009, 2010
|
|
|
|
.An Mark Adler Aq madler@alumni.caltech.edu
|