zstd
Original author(s) | Yann Collet |
---|---|
Developer(s) | Yann Collet, Nick Terrell, Przemysław Skibiński[1] |
Initial release | 23 January 2015 |
Stable release | 1.5.2
/ 20 January 2022[2] |
Repository | |
Written in | C |
Operating system | Cross-platform |
Platform | Portable |
Type | Data compression |
License | Dual: BSD License, GPLv2 |
Website | facebook |
Zstandard, commonly known by the name of its reference implementation zstd, is a lossless data compression algorithm developed by Yann Collet at Facebook. Zstd is the reference implementation in C. Version 1 of this implementation was released as open-source software on 31 August 2016.[3][4]
Features
Zstandard was designed to give a compression ratio comparable to that of the DEFLATE algorithm (developed in 1991 and used in the original ZIP and gzip programs), but faster, especially for decompression. It is tunable with compression levels ranging from negative 7 (fastest)[5] to 22 (slowest in compression speed, but best compression ratio).
The zstd package includes parallel (multi-threaded) implementations of both compression and decompression[citation needed]. Starting from version 1.3.2 (October 2017), zstd optionally implements very long range search and deduplication (--long
, 128 MiB window) similar to rzip or lrzip.[6]
Compression speed can vary by a factor of 20 or more between the fastest and slowest levels, while decompression is uniformly fast, varying by less than 20% between the fastest and slowest levels.[7] Zstandard command-line has an "adaptive" (--adapt
) mode that varies compression level depending on I/O conditions, mainly how fast it can write the output.
Zstd at its maximum compression level gives a compression ratio close to lzma, lzham, and ppmx, and performs better than lza, or bzip2.[8][9] Zstandard reaches the current Pareto frontier, as it decompresses faster than any other currently available algorithm with similar or better compression ratio.[10][11]
Dictionaries can have a large impact on the compression ratio of small files, so Zstandard can use a user-provided compression dictionary. It also offers a training mode, able to generate a dictionary from a set of samples.[12][13] In particular, one dictionary can be loaded to process large sets of files with redundancy between files, but not necessarily within each file, e.g., log files.
Design
Zstandard combines a dictionary-matching stage (LZ77) with a large search window and a fast entropy-coding stage. It uses both Huffman coding (used for entries in the Literals section)[14] and finite-state entropy (FSE) - a fast tabled version of ANS, tANS, used for entries in the Sequences section. Because of the way that FSE carries over state between symbols, decompression involves processing symbols within the Sequences section of each block in reverse order (from last to first).
Usage
Filename extension |
.zst[15] |
---|---|
Internet media type |
application/zstd[15] |
Magic number | 28 b5 2f fd [15] |
Type of format | Data compression |
Standard | RFC 8478 |
Website | github |
Internet media type | application/zstd |
---|---|
Magic number | 37 a4 30 ec [15] |
Standard | RFC 8478 |
Website | github |
The Linux kernel has included Zstandard since November 2017 (version 4.14) as a compression method for the btrfs and squashfs filesystems.[16][17][18]
In 2017, Allan Jude integrated Zstandard into the FreeBSD kernel,[19] and it was subsequently integrated as a compressor option for core dumps (both user programs and kernel panics). It was also used to create a proof-of-concept OpenZFS compression method[7] which was integrated in 2020.[20]
The AWS Redshift and RocksDB databases include support for field compression using Zstandard.[21]
In March 2018, Canonical tested[22] the use of zstd as a deb package compression method by default for the Ubuntu Linux distribution. Compared with xz compression of deb packages, zstd at level 19 decompresses significantly faster, but at the cost of 6% larger package files. Support was added to Debian (and subsequently, Ubuntu) in April 2018 (in version 1.6~rc1).[23][24][25]
In 2018 the algorithm was published as RFC 8478, which also defines an associated media type "application/zstd", filename extension "zst", and HTTP content encoding "zstd".[15]
Arch Linux added support for zstd as a package compression method in October 2019 with the release of the pacman 5.2 package manager[26] and in January 2020 switched from xz to zstd for the packages in the official repository. Arch uses zstd -c -T0 --ultra -20 -
, the size of all compressed packages combined increased by 0.8% (compared to xz), the decompression speed is 13 times faster, decompression memory increased by 50 MiB when using multiple threads, compression memory increases but scales with the number of threads used.[27][28][29] Arch Linux later also switched to zstd as default compression algorithm for mkinitcpio initial ramdisk generator.[30]
Fedora added ZStandard support to RPM in May 2018 (Fedora release 28) and used it for packaging the release in October 2019 (Fedora 31).[31] In Fedora 33, the filesystem is compressed by default with zstd.[32][33]
Full implementation of the algorithm with an option to choose the compression level is used in the .NSZ/.XCZ[34] file formats developed by the homebrew community for the Nintendo Switch hybrid game console.[35] Similarly, it is also one of many supported compression algorithms in the .RVZ Nintendo Wii and Nintendo GameCube disc image file format.
In 2020, Zstandard was implemented in version 6.3.8 of the zip file format with codec number 93. Previous number 20 of version 6.3.7 was deprecated[clarification needed], so a second file format with zip is available for Zstandard files. New versions of zip programs often support this new feature.
7-Zip ZS, a fork of 7-Zip FM with Zstandard (and other formats) support, is developed by Tino Reichardt.[36] Actual is here support of Zstandard 1.5.0.
Modern7z, a Zstandard (and other formats) plugin for 7-Zip FM is developed by Denis Anisimov (TC4shell).[37]
p7zip also supports in a new version Zstandard 1.4.9.[38]
License
The reference implementation is licensed under the BSD license, published at GitHub.[39] Since version 1.0, it had an additional Grant of Patent Rights.[40]
From version 1.3.1,[41] this patent grant was dropped and the license was changed to a BSD + GPLv2 dual license.[42]
See also
- Zlib
- LZFSE – a similar algorithm by Apple used since iOS 9 and OS X 10.11 made open source on 1 June 2016
- LZ4 (compression algorithm) – a fast member of the LZ77 family
References
- ^ "Contributors to facebook/zstd". github.com. Archived from the original on 27 January 2021. Retrieved 26 January 2021.
- ^ "Releases - facebook/zstd". Retrieved 20 January 2022 – via GitHub.
- ^ Sergio De Simone (2 September 2016). "Facebook Open-Sources New Compression Algorithm Outperforming Zlib". InfoQ. Retrieved 20 April 2019.
- ^ "Life imitates satire: Facebook touts zlib killer just like Silicon Valley's Pied Piper". The Register. 31 August 2016. Retrieved 6 September 2016.
- ^ https://github.com/facebook/zstd/releases/tag/v1.3.4 Faster compression levels.
- ^ "Command Line Interface for Zstandard library". GitHub. 28 October 2021.
- ^ a b "ZStandard in ZFS" (PDF). open-zfs.org. 2017. Retrieved 20 April 2019.
- ^ Matt Mahoney. "Silesia Open Source Compression Benchmark". Retrieved 10 May 2019.
- ^ Matt Mahoney (29 August 2016). "Large Text Compression Benchmark, .2157 zstd". Retrieved 1 September 2016.
- ^ TurboBench: Static/Dynamic web content compression benchmark, PowTurbo
- ^ Matt Mahoney, Silesia Open Source Compression Benchmark
- ^ "Facebook developers report massive speedups and compression ratio improvements when using dictionaries" (PDF).
- ^ "Smaller and faster data compression with Zstandard". Facebook. 31 August 2016.
- ^ "facebook/zstd". GitHub. 28 October 2021.
- ^ a b c d e Collet, Yann (October 2018). Kucherawy, Murray S. (ed.). Zstandard Compression and the application/zstd Media Type. Internet Engineering Task Force Request for Comments. doi:10.17487/RFC8478. RFC 8478. Retrieved 7 October 2020.
- ^ "The rest of the 4.14 merge window [LWN.net]". lwn.net.
- ^ "Linux_4.14 - Linux Kernel Newbies". Kernelnewbies.org. Retrieved 16 August 2018.
- ^ "Zstd Compression For Btrfs & Squashfs Set For Linux 4.14, Already Used Within Facebook - Phoronix". www.phoronix.com.
- ^ "Integrate ZSTD into the kernel · freebsd/Freebsd-SRC@28ef165". GitHub.
- ^ "Add ZSTD support to ZFS · openzfs/ZFS@10b3c7f". GitHub.
- ^ "Zstandard Encoding - Amazon Redshift". 20 April 2019.
- ^ Larabel, Michael (12 March 2018). "Canonical Working On Zstd-Compressed Debian Packages For Ubuntu". phoronix.com. Phoronix Media. Retrieved 29 October 2019.
The developers at Canonical are considering a feature freeze exception to get this newly-developed Zstd Apt/Dpkg support in Ubuntu 18.04 LTS. In doing so, they mention they would be looking at enabling Zstd compression for packages by default in Ubuntu 18.10.
- ^ "New Ubuntu Installs Could Be Speed Up by 10% with the Zstd Compression Algorithm". Softpedia. 12 March 2018. Retrieved 13 August 2018.
- ^ "Canonical Working On Zstd-Compressed Debian Packages For Ubuntu". phoronix. 12 March 2018. Retrieved 13 August 2018.
- ^ "Debian Changelog for apt". Debian. 19 April 2021. Retrieved 7 November 2022.
- ^ "Arch Linux Nears Roll-Out of ZSTD Compressed Packages for Faster Pacman Installs". Phoronix.
- ^ Broda, Mara (4 January 2020). "Now using Zstandard instead of xz for package compression". Arch Linux. Retrieved 5 January 2020.
- ^ Broda, Mara (25 March 2019). "RFC: (devtools) Changing default compression method to zstd". arch-dev-public (Mailing list).
- ^ Broda, Mara; Polyak, Levente (27 December 2019). "makepkg.conf: change default compression method to zstd". GitHub.
- ^ Razzolini, Giancarlo (19 February 2021). "News: Moving to Zstandard images by default on mkinitcpio". Arch Linux. Retrieved 28 December 2021.
{{cite web}}
: CS1 maint: url-status (link) - ^ "Changes/Switch RPMS to ZSTD compression". Fedora Project Wiki.
- ^ "Fedora Workstation 34 feature focus: Btrfs transparent compression". Fedora Magazine. 14 April 2021. Retrieved 12 May 2022.
- ^ "Changes/BtrfsTransparentCompression". Fedora Project Wiki. Retrieved 12 May 2022.
- ^ "RELEASE - nsZip - NSP compressor/decompressor to reduce storage". GBAtemp.net - The Independent Video Game Community. Retrieved 3 November 2019.
- ^ Bosshard, Nico (31 October 2019), nsZip is a tool to compress/decompress Nintendo Switch games using the here specified NSZ file format: nicoboss/nsZip, retrieved 3 November 2019
- ^ "7-Zip with support for Zstandard, Brotli, Lz4, Lz5 and Lizard Compression". Milkys Homepage.
- ^ "Modern7z".
- ^ "jinfeihan57/p7zip: A new p7zip fork with additional codecs and improvements". GitHub. Retrieved 6 August 2022.
- ^ "Facebook open sources Zstandard data compression algorithm, aims to replace technology behind Zip". ZDnet. 31 August 2016. Retrieved 1 September 2016.
- ^ zstd/PATENTS "Additional Grant of Patent Rights Version 2", Facebook
- ^ "Zstd v1.3.1 release", GitHub "facebook/zstd"
- ^ "New license", GitHub "facebook/zstd"
External links
- Official website
- zstd on GitHub
- 7zip with Zstandard on GitHub
- "Smaller and faster data compression with Zstandard", Yann Collet and Chip Turner, 31 August 2016, Facebook Announcement
- The Guardian is using ZStandard instead of zlib