mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-18 13:36:36 +01:00
publish: Add support for zstd compression.
* guix/scripts/publish.scm (compress-nar)[write-compressed-file]: New procedure. Use it for 'gzip' and 'lzip'. Add 'zstd. (nar-response-port, string->compression-type): Add case for 'zstd'. * tests/publish.scm (zstd-supported?): New procedure. ("/nar/zstd/*"): New test. * doc/guix.texi (Invoking guix publish): Document zstd compression. (Base Services): Add cross-reference to the above node.
This commit is contained in:
parent
db0cecdf6b
commit
d288a4de7d
3 changed files with 49 additions and 20 deletions
|
@ -12348,17 +12348,23 @@ server socket is open and the signing key has been read.
|
|||
@item --compression[=@var{method}[:@var{level}]]
|
||||
@itemx -C [@var{method}[:@var{level}]]
|
||||
Compress data using the given @var{method} and @var{level}. @var{method} is
|
||||
one of @code{lzip} and @code{gzip}; when @var{method} is omitted, @code{gzip}
|
||||
is used.
|
||||
one of @code{lzip}, @code{zstd}, and @code{gzip}; when @var{method} is
|
||||
omitted, @code{gzip} is used.
|
||||
|
||||
When @var{level} is zero, disable compression. The range 1 to 9 corresponds
|
||||
to different compression levels: 1 is the fastest, and 9 is the best
|
||||
(CPU-intensive). The default is 3.
|
||||
|
||||
Usually, @code{lzip} compresses noticeably better than @code{gzip} for a small
|
||||
increase in CPU usage; see
|
||||
@uref{https://nongnu.org/lzip/lzip_benchmark.html,benchmarks on the lzip Web
|
||||
page}.
|
||||
Usually, @code{lzip} compresses noticeably better than @code{gzip} for a
|
||||
small increase in CPU usage; see
|
||||
@uref{https://nongnu.org/lzip/lzip_benchmark.html,benchmarks on the lzip
|
||||
Web page}. However, @code{lzip} achieves low decompression throughput
|
||||
(on the order of 50@tie{}MiB/s on modern hardware), which can be a
|
||||
bottleneck for someone who downloads over a fast network connection.
|
||||
|
||||
The compression ratio of @code{zstd} is between that of @code{lzip} and
|
||||
that of @code{gzip}; its main advantage is a
|
||||
@uref{https://facebook.github.io/zstd/,high decompression speed}.
|
||||
|
||||
Unless @option{--cache} is used, compression occurs on the fly and
|
||||
the compressed streams are not
|
||||
|
@ -15400,7 +15406,9 @@ at level 7 and gzip at level 9, write:
|
|||
@end lisp
|
||||
|
||||
Level 9 achieves the best compression ratio at the expense of increased CPU
|
||||
usage, whereas level 1 achieves fast compression.
|
||||
usage, whereas level 1 achieves fast compression. @xref{Invoking guix
|
||||
publish}, for more information on the available compression methods and
|
||||
the tradeoffs involved.
|
||||
|
||||
An empty list disables compression altogether.
|
||||
|
||||
|
|
|
@ -56,6 +56,8 @@ (define-module (guix scripts publish)
|
|||
#:use-module (zlib)
|
||||
#:autoload (lzlib) (call-with-lzip-output-port
|
||||
make-lzip-output-port)
|
||||
#:autoload (zstd) (call-with-zstd-output-port
|
||||
make-zstd-output-port)
|
||||
#:use-module (guix cache)
|
||||
#:use-module (guix ui)
|
||||
#:use-module (guix scripts)
|
||||
|
@ -588,23 +590,22 @@ (define (compress-nar cache item compression)
|
|||
(define nar
|
||||
(nar-cache-file cache item #:compression compression))
|
||||
|
||||
(define (write-compressed-file call-with-compressed-output-port)
|
||||
;; Note: the file port gets closed along with the compressed port.
|
||||
(call-with-compressed-output-port (open-output-file (string-append nar ".tmp"))
|
||||
(lambda (port)
|
||||
(write-file item port))
|
||||
#:level (compression-level compression))
|
||||
(rename-file (string-append nar ".tmp") nar))
|
||||
|
||||
(mkdir-p (dirname nar))
|
||||
(match (compression-type compression)
|
||||
('gzip
|
||||
;; Note: the file port gets closed along with the gzip port.
|
||||
(call-with-gzip-output-port (open-output-file (string-append nar ".tmp"))
|
||||
(lambda (port)
|
||||
(write-file item port))
|
||||
#:level (compression-level compression)
|
||||
#:buffer-size %default-buffer-size)
|
||||
(rename-file (string-append nar ".tmp") nar))
|
||||
(write-compressed-file call-with-gzip-output-port))
|
||||
('lzip
|
||||
;; Note: the file port gets closed along with the lzip port.
|
||||
(call-with-lzip-output-port (open-output-file (string-append nar ".tmp"))
|
||||
(lambda (port)
|
||||
(write-file item port))
|
||||
#:level (compression-level compression))
|
||||
(rename-file (string-append nar ".tmp") nar))
|
||||
(write-compressed-file call-with-lzip-output-port))
|
||||
('zstd
|
||||
(write-compressed-file call-with-zstd-output-port))
|
||||
('none
|
||||
;; Cache nars even when compression is disabled so that we can
|
||||
;; guarantee the TTL (see <https://bugs.gnu.org/28664>.)
|
||||
|
@ -871,6 +872,9 @@ (define (nar-response-port response compression)
|
|||
(($ <compression> 'lzip level)
|
||||
(make-lzip-output-port (response-port response)
|
||||
#:level level))
|
||||
(($ <compression> 'zstd level)
|
||||
(make-zstd-output-port (response-port response)
|
||||
#:level level))
|
||||
(($ <compression> 'none)
|
||||
(response-port response))
|
||||
(#f
|
||||
|
@ -953,6 +957,7 @@ (define (string->compression-type string)
|
|||
(match string
|
||||
("gzip" 'gzip)
|
||||
("lzip" 'lzip)
|
||||
("zstd" 'zstd)
|
||||
(_ #f)))
|
||||
|
||||
(define (effective-compression requested-type compressions)
|
||||
|
|
|
@ -38,6 +38,7 @@ (define-module (test-publish)
|
|||
#:use-module ((guix pki) #:select (%public-key-file %private-key-file))
|
||||
#:use-module (zlib)
|
||||
#:use-module (lzlib)
|
||||
#:autoload (zstd) (call-with-zstd-input-port)
|
||||
#:use-module (web uri)
|
||||
#:use-module (web client)
|
||||
#:use-module (web response)
|
||||
|
@ -54,6 +55,9 @@ (define-module (test-publish)
|
|||
(define %store
|
||||
(open-connection-for-tests))
|
||||
|
||||
(define (zstd-supported?)
|
||||
(resolve-module '(zstd) #t #f #:ensure #f))
|
||||
|
||||
(define %reference (add-text-to-store %store "ref" "foo"))
|
||||
|
||||
(define %item (add-text-to-store %store "item" "bar" (list %reference)))
|
||||
|
@ -237,6 +241,18 @@ (define %gzip-magic-bytes
|
|||
(cut restore-file <> temp)))
|
||||
(call-with-input-file temp read-string))))
|
||||
|
||||
(unless (zstd-supported?) (test-skip 1))
|
||||
(test-equal "/nar/zstd/*"
|
||||
"bar"
|
||||
(call-with-temporary-output-file
|
||||
(lambda (temp port)
|
||||
(let ((nar (http-get-port
|
||||
(publish-uri
|
||||
(string-append "/nar/zstd/" (basename %item))))))
|
||||
(call-with-zstd-input-port nar
|
||||
(cut restore-file <> temp)))
|
||||
(call-with-input-file temp read-string))))
|
||||
|
||||
(test-equal "/*.narinfo with compression"
|
||||
`(("StorePath" . ,%item)
|
||||
("URL" . ,(string-append "nar/gzip/" (basename %item)))
|
||||
|
|
Loading…
Reference in a new issue