leveldb/table
leveldb Team 1d6e8d64ee Add support for Zstd-based compression in LevelDB.
This change implements support for Zstd-based compression in LevelDB. Building
up from the Snappy compression (which has been supported since inception), this
change adds Zstd as an alternate compression algorithm.

We are implementing this to provide alternative options for users who might
have different performance and efficiency requirements. For instance, the
Zstandard website (https://facebook.github.io/zstd/) claims that the Zstd
algorithm can achieve around 30% higher compression ratios than Snappy, with
relatively smaller (~10%) slowdowns in de/compression speeds.

Benchmarking results:

$ blaze-bin/third_party/leveldb/db_bench
LevelDB:    version 1.23
Date:       Thu Feb  2 18:50:06 2023
CPU:        56 * Intel(R) Xeon(R) CPU E5-2690 v4 @ 2.60GHz
CPUCache:   35840 KB
Keys:       16 bytes each
Values:     100 bytes each (50 bytes after compression)
Entries:    1000000
RawSize:    110.6 MB (estimated)
FileSize:   62.9 MB (estimated)
------------------------------------------------
fillseq      :       2.613 micros/op;   42.3 MB/s
fillsync     :    3924.432 micros/op;    0.0 MB/s (1000 ops)
fillrandom   :       3.609 micros/op;   30.7 MB/s
overwrite    :       4.508 micros/op;   24.5 MB/s
readrandom   :       6.136 micros/op; (864322 of 1000000 found)
readrandom   :       5.446 micros/op; (864083 of 1000000 found)
readseq      :       0.180 micros/op;  613.3 MB/s
readreverse  :       0.321 micros/op;  344.7 MB/s
compact      :  827043.000 micros/op;
readrandom   :       4.603 micros/op; (864105 of 1000000 found)
readseq      :       0.169 micros/op;  656.3 MB/s
readreverse  :       0.315 micros/op;  350.8 MB/s
fill100K     :     854.009 micros/op;  111.7 MB/s (1000 ops)
crc32c       :       1.227 micros/op; 3184.0 MB/s (4K per op)
snappycomp   :       3.610 micros/op; 1081.9 MB/s (output: 55.2%)
snappyuncomp :       0.691 micros/op; 5656.3 MB/s
zstdcomp     :      15.731 micros/op;  248.3 MB/s (output: 44.1%)
zstduncomp   :       4.218 micros/op;  926.2 MB/s
PiperOrigin-RevId: 509957778
2023-03-28 16:49:13 -07:00
..
block_builder.cc Switch from C headers to C++ headers. 2020-04-29 20:51:13 +00:00
block_builder.h Switch from C headers to C++ headers. 2020-04-29 20:51:13 +00:00
block.cc Optimize leveldb block seeks to utilize the current iterator location. 2021-01-11 15:41:38 +00:00
block.h Switch from C headers to C++ headers. 2020-04-29 20:51:13 +00:00
filter_block_test.cc Remove main() from most tests. 2022-01-03 21:05:04 +00:00
filter_block.cc Format all files IAW the Google C++ Style Guide. 2019-05-02 19:04:50 -07:00
filter_block.h Switch from C headers to C++ headers. 2020-04-29 20:51:13 +00:00
format.cc Add support for Zstd-based compression in LevelDB. 2023-03-28 16:49:13 -07:00
format.h Switch from C headers to C++ headers. 2020-04-29 20:51:13 +00:00
iterator_wrapper.h Format all files IAW the Google C++ Style Guide. 2019-05-02 19:04:50 -07:00
iterator.cc Format all files IAW the Google C++ Style Guide. 2019-05-02 19:04:50 -07:00
merger.cc Switch to using C++ 11 override specifier. 2019-05-09 14:11:06 -07:00
merger.h Format all files IAW the Google C++ Style Guide. 2019-05-02 19:04:50 -07:00
table_builder.cc Add support for Zstd-based compression in LevelDB. 2023-03-28 16:49:13 -07:00
table_test.cc Add support for Zstd-based compression in LevelDB. 2023-03-28 16:49:13 -07:00
table.cc remove unnessary status judge 2020-04-24 02:00:12 +00:00
two_level_iterator.cc Switch to using C++ 11 override specifier. 2019-05-09 14:11:06 -07:00
two_level_iterator.h Format all files IAW the Google C++ Style Guide. 2019-05-02 19:04:50 -07:00