mirror of https://git.tukaani.org/xz.git
xz: Update the man page for threaded decompression and memlimits.
This documents the changes made in commits6c6da57ae2
,cad299008c
, and898faa9728
. The --info-memory bit hasn't been finished yet even though it's already mentioned in this commit under --memlimit-mt-decompress and --threads.
This commit is contained in:
parent
d13bfcc005
commit
f864f6d42e
148
src/xz/xz.1
148
src/xz/xz.1
|
@ -5,7 +5,7 @@
|
||||||
.\" This file has been put into the public domain.
|
.\" This file has been put into the public domain.
|
||||||
.\" You can do whatever you want with this file.
|
.\" You can do whatever you want with this file.
|
||||||
.\"
|
.\"
|
||||||
.TH XZ 1 "2022-07-24" "Tukaani" "XZ Utils"
|
.TH XZ 1 "2022-08-19" "Tukaani" "XZ Utils"
|
||||||
.
|
.
|
||||||
.SH NAME
|
.SH NAME
|
||||||
xz, unxz, xzcat, lzma, unlzma, lzcat \- Compress or decompress .xz and .lzma files
|
xz, unxz, xzcat, lzma, unlzma, lzcat \- Compress or decompress .xz and .lzma files
|
||||||
|
@ -964,15 +964,28 @@ the last one takes effect.
|
||||||
If the compression settings exceed the
|
If the compression settings exceed the
|
||||||
.IR limit ,
|
.IR limit ,
|
||||||
.B xz
|
.B xz
|
||||||
will adjust the settings downwards so that
|
will attempt to adjust the settings downwards so that
|
||||||
the limit is no longer exceeded and display a notice that
|
the limit is no longer exceeded and display a notice that
|
||||||
automatic adjustment was done.
|
automatic adjustment was done.
|
||||||
Such adjustments are not made when compressing with
|
The adjustments are done in this order:
|
||||||
|
reducing the number of threads,
|
||||||
|
switching to single-threaded mode
|
||||||
|
if even one thread in multi-threaded mode exceeds the
|
||||||
|
.IR limit ,
|
||||||
|
and finally reducing the LZMA2 dictionary size.
|
||||||
|
.IP ""
|
||||||
|
When compressing with
|
||||||
.B \-\-format=raw
|
.B \-\-format=raw
|
||||||
or if
|
or if
|
||||||
.B \-\-no\-adjust
|
.B \-\-no\-adjust
|
||||||
has been specified.
|
has been specified,
|
||||||
In those cases, an error is displayed and
|
only the number of threads may be reduced
|
||||||
|
since it can be done without affecting the compressed output.
|
||||||
|
.IP ""
|
||||||
|
If the
|
||||||
|
.I limit
|
||||||
|
cannot be met even with the adjustments described above,
|
||||||
|
an error is displayed and
|
||||||
.B xz
|
.B xz
|
||||||
will exit with exit status 1.
|
will exit with exit status 1.
|
||||||
.IP ""
|
.IP ""
|
||||||
|
@ -1011,16 +1024,6 @@ This is currently equivalent to setting the
|
||||||
to
|
to
|
||||||
.B max
|
.B max
|
||||||
(no memory usage limit).
|
(no memory usage limit).
|
||||||
Once multithreading support has been implemented,
|
|
||||||
there may be a difference between
|
|
||||||
.B 0
|
|
||||||
and
|
|
||||||
.B max
|
|
||||||
for the multithreaded case, so it is recommended to use
|
|
||||||
.B 0
|
|
||||||
instead of
|
|
||||||
.B max
|
|
||||||
until the details have been decided.
|
|
||||||
.RE
|
.RE
|
||||||
.IP ""
|
.IP ""
|
||||||
For 32-bit
|
For 32-bit
|
||||||
|
@ -1063,16 +1066,73 @@ See
|
||||||
for possible ways to specify the
|
for possible ways to specify the
|
||||||
.IR limit .
|
.IR limit .
|
||||||
.TP
|
.TP
|
||||||
|
.BI \-\-memlimit\-mt\-decompress= limit
|
||||||
|
Set a memory usage limit for decompression that can only affect
|
||||||
|
the number of threads.
|
||||||
|
Unlike
|
||||||
|
.BR \-\-memlimit\-decompress ,
|
||||||
|
this
|
||||||
|
.I limit
|
||||||
|
will never make
|
||||||
|
.B xz
|
||||||
|
refuse to decompress a file.
|
||||||
|
If even single-threaded mode will exceed the
|
||||||
|
.I limit
|
||||||
|
then the
|
||||||
|
.I limit
|
||||||
|
is ignored and
|
||||||
|
.B xz
|
||||||
|
will decompress in single-threaded mode anyway.
|
||||||
|
.IP ""
|
||||||
|
In contrast to the other memory usage limit options,
|
||||||
|
.BI \-\-memlimit\-mt\-decompress= limit
|
||||||
|
has a system-specific default
|
||||||
|
.IR limit .
|
||||||
|
.B "xz \-\-info\-memory"
|
||||||
|
can be used to see the current value.
|
||||||
|
.IP ""
|
||||||
|
This option and its default value exist
|
||||||
|
because without any limit the threaded decompressor
|
||||||
|
could end up allocating an insane amount of memory with some input files.
|
||||||
|
If the default
|
||||||
|
.I limit
|
||||||
|
is too low on your system,
|
||||||
|
feel free to increase the
|
||||||
|
.I limit
|
||||||
|
but never set it to a value larger than the amount of usable RAM
|
||||||
|
as with appropriate input files
|
||||||
|
.B xz
|
||||||
|
will attempt to use that amount of memory
|
||||||
|
even with a low number of threads.
|
||||||
|
Running out of memory or swapping
|
||||||
|
will not improve decompression performance.
|
||||||
|
.IP ""
|
||||||
|
See
|
||||||
|
.BI \-\-memlimit\-compress= limit
|
||||||
|
for possible ways to specify the
|
||||||
|
.IR limit .
|
||||||
|
Setting
|
||||||
|
.I limit
|
||||||
|
to
|
||||||
|
.B 0
|
||||||
|
resets it to the default system-specific value.
|
||||||
|
.TP
|
||||||
\fB\-M\fR \fIlimit\fR, \fB\-\-memlimit=\fIlimit\fR, \fB\-\-memory=\fIlimit
|
\fB\-M\fR \fIlimit\fR, \fB\-\-memlimit=\fIlimit\fR, \fB\-\-memory=\fIlimit
|
||||||
This is equivalent to specifying
|
This is equivalent to specifying
|
||||||
.BI \-\-memlimit\-compress= limit
|
.BI \-\-memlimit\-compress= limit
|
||||||
\fB\-\-memlimit\-decompress=\fIlimit\fR.
|
.BI \-\-memlimit-decompress= limit
|
||||||
|
\fB\-\-memlimit\-mt\-decompress=\fIlimit\fR.
|
||||||
.TP
|
.TP
|
||||||
.B \-\-no\-adjust
|
.B \-\-no\-adjust
|
||||||
Display an error and exit if the compression settings exceed
|
Display an error and exit if the memory usage limit cannot be
|
||||||
the memory usage limit.
|
met without adjusting settings that affect the compressed output.
|
||||||
The default is to adjust the settings downwards so
|
That is, this prevents
|
||||||
that the memory usage limit is not exceeded.
|
.B xz
|
||||||
|
from switching the encoder from multi-threaded mode to single-threaded mode
|
||||||
|
and from reducing the LZMA2 dictionary size.
|
||||||
|
Even when this option is used the number of threads may be reduced
|
||||||
|
to meet the memory usage limit as that won't affect the compressed output.
|
||||||
|
.IP ""
|
||||||
Automatic adjusting is always disabled when creating raw streams
|
Automatic adjusting is always disabled when creating raw streams
|
||||||
.RB ( \-\-format=raw ).
|
.RB ( \-\-format=raw ).
|
||||||
.TP
|
.TP
|
||||||
|
@ -1084,13 +1144,47 @@ to a special value
|
||||||
.B 0
|
.B 0
|
||||||
makes
|
makes
|
||||||
.B xz
|
.B xz
|
||||||
use as many threads as there are CPU cores on the system.
|
use up to as many threads as the processor(s) on the system support.
|
||||||
The actual number of threads can be less than
|
The actual number of threads can be fewer than
|
||||||
.I threads
|
.I threads
|
||||||
if the input file is not big enough
|
if the input file is not big enough
|
||||||
for threading with the given settings or
|
for threading with the given settings or
|
||||||
if using more threads would exceed the memory usage limit.
|
if using more threads would exceed the memory usage limit.
|
||||||
.IP ""
|
.IP ""
|
||||||
|
The single-threaded and multi-threaded compressors produce different output.
|
||||||
|
Single-threaded compressor will give the smallest file size but
|
||||||
|
only the output from the multi-threaded compressor can be decompressed
|
||||||
|
using multiple threads.
|
||||||
|
Setting
|
||||||
|
.I threads
|
||||||
|
to
|
||||||
|
.B 1
|
||||||
|
will use the single-threaded mode.
|
||||||
|
Setting
|
||||||
|
.I threads
|
||||||
|
to any other value, including
|
||||||
|
.BR 0 ,
|
||||||
|
will use the multi-threaded compressor
|
||||||
|
even if the system supports only one hardware thread.
|
||||||
|
.RB ( xz
|
||||||
|
5.2.x
|
||||||
|
used single-threaded mode in this situation.)
|
||||||
|
.IP ""
|
||||||
|
If an automatic number of threads has been requested and
|
||||||
|
no memory usage limit has been specified,
|
||||||
|
then a system-specific default soft limit will be used to possibly
|
||||||
|
limit the number of threads.
|
||||||
|
It is a soft limit in sense that it is ignored
|
||||||
|
if the number of threads becomes one,
|
||||||
|
thus a soft limit will never stop
|
||||||
|
.B xz
|
||||||
|
from compressing or decompressing.
|
||||||
|
This default soft limit will not make
|
||||||
|
.B xz
|
||||||
|
switch from multi-threaded mode to single-threaded mode.
|
||||||
|
The active limits can be seen with
|
||||||
|
.BR "xz \-\-info\-memory" .
|
||||||
|
.IP ""
|
||||||
Currently the only threading method is to split the input into
|
Currently the only threading method is to split the input into
|
||||||
blocks and compress them independently from each other.
|
blocks and compress them independently from each other.
|
||||||
The default block size depends on the compression level and
|
The default block size depends on the compression level and
|
||||||
|
@ -1098,13 +1192,13 @@ can be overridden with the
|
||||||
.BI \-\-block\-size= size
|
.BI \-\-block\-size= size
|
||||||
option.
|
option.
|
||||||
.IP ""
|
.IP ""
|
||||||
Threaded decompression hasn't been implemented yet.
|
Threaded decompression only works on files that contain
|
||||||
It will only work on files that contain multiple blocks
|
multiple blocks with size information in block headers.
|
||||||
with size information in block headers.
|
All large enough files compressed in multi-threaded mode
|
||||||
All files compressed in multi-threaded mode meet this condition,
|
meet this condition,
|
||||||
but files compressed in single-threaded mode don't even if
|
but files compressed in single-threaded mode don't even if
|
||||||
.BI \-\-block\-size= size
|
.BI \-\-block\-size= size
|
||||||
is used.
|
has been used.
|
||||||
.
|
.
|
||||||
.SS "Custom compressor filter chains"
|
.SS "Custom compressor filter chains"
|
||||||
A custom filter chain allows specifying
|
A custom filter chain allows specifying
|
||||||
|
|
Loading…
Reference in New Issue