|
|
@ -45,6 +45,7 @@ int main() { |
|
|
|
#include "port/port.h" |
|
|
|
#include "port/port.h" |
|
|
|
#include "port/stack_trace.h" |
|
|
|
#include "port/stack_trace.h" |
|
|
|
#include "util/crc32c.h" |
|
|
|
#include "util/crc32c.h" |
|
|
|
|
|
|
|
#include "util/compression.h" |
|
|
|
#include "util/histogram.h" |
|
|
|
#include "util/histogram.h" |
|
|
|
#include "util/mutexlock.h" |
|
|
|
#include "util/mutexlock.h" |
|
|
|
#include "util/random.h" |
|
|
|
#include "util/random.h" |
|
|
@ -1213,27 +1214,27 @@ class Benchmark { |
|
|
|
text[len] = '\0'; |
|
|
|
text[len] = '\0'; |
|
|
|
switch (FLAGS_compression_type_e) { |
|
|
|
switch (FLAGS_compression_type_e) { |
|
|
|
case kSnappyCompression: |
|
|
|
case kSnappyCompression: |
|
|
|
result = port::Snappy_Compress(Options().compression_opts, text, |
|
|
|
result = Snappy_Compress(Options().compression_opts, text, |
|
|
|
strlen(text), &compressed); |
|
|
|
strlen(text), &compressed); |
|
|
|
name = "Snappy"; |
|
|
|
name = "Snappy"; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case kZlibCompression: |
|
|
|
case kZlibCompression: |
|
|
|
result = port::Zlib_Compress(Options().compression_opts, text, |
|
|
|
result = Zlib_Compress(Options().compression_opts, text, strlen(text), |
|
|
|
strlen(text), &compressed); |
|
|
|
&compressed); |
|
|
|
name = "Zlib"; |
|
|
|
name = "Zlib"; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case kBZip2Compression: |
|
|
|
case kBZip2Compression: |
|
|
|
result = port::BZip2_Compress(Options().compression_opts, text, |
|
|
|
result = BZip2_Compress(Options().compression_opts, text, |
|
|
|
strlen(text), &compressed); |
|
|
|
strlen(text), &compressed); |
|
|
|
name = "BZip2"; |
|
|
|
name = "BZip2"; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case kLZ4Compression: |
|
|
|
case kLZ4Compression: |
|
|
|
result = port::LZ4_Compress(Options().compression_opts, text, |
|
|
|
result = LZ4_Compress(Options().compression_opts, text, strlen(text), |
|
|
|
strlen(text), &compressed); |
|
|
|
&compressed); |
|
|
|
name = "LZ4"; |
|
|
|
name = "LZ4"; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case kLZ4HCCompression: |
|
|
|
case kLZ4HCCompression: |
|
|
|
result = port::LZ4HC_Compress(Options().compression_opts, text, |
|
|
|
result = LZ4HC_Compress(Options().compression_opts, text, |
|
|
|
strlen(text), &compressed); |
|
|
|
strlen(text), &compressed); |
|
|
|
name = "LZ4HC"; |
|
|
|
name = "LZ4HC"; |
|
|
|
break; |
|
|
|
break; |
|
|
@ -1774,23 +1775,23 @@ class Benchmark { |
|
|
|
while (ok && bytes < int64_t(1) << 30) { |
|
|
|
while (ok && bytes < int64_t(1) << 30) { |
|
|
|
switch (FLAGS_compression_type_e) { |
|
|
|
switch (FLAGS_compression_type_e) { |
|
|
|
case rocksdb::kSnappyCompression: |
|
|
|
case rocksdb::kSnappyCompression: |
|
|
|
ok = port::Snappy_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = Snappy_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kZlibCompression: |
|
|
|
case rocksdb::kZlibCompression: |
|
|
|
ok = port::Zlib_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = Zlib_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kBZip2Compression: |
|
|
|
case rocksdb::kBZip2Compression: |
|
|
|
ok = port::BZip2_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = BZip2_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kLZ4Compression: |
|
|
|
case rocksdb::kLZ4Compression: |
|
|
|
ok = port::LZ4_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = LZ4_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kLZ4HCCompression: |
|
|
|
case rocksdb::kLZ4HCCompression: |
|
|
|
ok = port::LZ4HC_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = LZ4HC_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
default: |
|
|
|
default: |
|
|
@ -1820,23 +1821,23 @@ class Benchmark { |
|
|
|
bool ok; |
|
|
|
bool ok; |
|
|
|
switch (FLAGS_compression_type_e) { |
|
|
|
switch (FLAGS_compression_type_e) { |
|
|
|
case rocksdb::kSnappyCompression: |
|
|
|
case rocksdb::kSnappyCompression: |
|
|
|
ok = port::Snappy_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = Snappy_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kZlibCompression: |
|
|
|
case rocksdb::kZlibCompression: |
|
|
|
ok = port::Zlib_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = Zlib_Compress(Options().compression_opts, input.data(), input.size(), |
|
|
|
input.size(), &compressed); |
|
|
|
&compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kBZip2Compression: |
|
|
|
case rocksdb::kBZip2Compression: |
|
|
|
ok = port::BZip2_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = BZip2_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kLZ4Compression: |
|
|
|
case rocksdb::kLZ4Compression: |
|
|
|
ok = port::LZ4_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = LZ4_Compress(Options().compression_opts, input.data(), input.size(), |
|
|
|
input.size(), &compressed); |
|
|
|
&compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kLZ4HCCompression: |
|
|
|
case rocksdb::kLZ4HCCompression: |
|
|
|
ok = port::LZ4HC_Compress(Options().compression_opts, input.data(), |
|
|
|
ok = LZ4HC_Compress(Options().compression_opts, input.data(), |
|
|
|
input.size(), &compressed); |
|
|
|
input.size(), &compressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
default: |
|
|
|
default: |
|
|
@ -1851,27 +1852,27 @@ class Benchmark { |
|
|
|
case rocksdb::kSnappyCompression: |
|
|
|
case rocksdb::kSnappyCompression: |
|
|
|
// allocate here to make comparison fair
|
|
|
|
// allocate here to make comparison fair
|
|
|
|
uncompressed = new char[input.size()]; |
|
|
|
uncompressed = new char[input.size()]; |
|
|
|
ok = port::Snappy_Uncompress(compressed.data(), compressed.size(), |
|
|
|
ok = Snappy_Uncompress(compressed.data(), compressed.size(), |
|
|
|
uncompressed); |
|
|
|
uncompressed); |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kZlibCompression: |
|
|
|
case rocksdb::kZlibCompression: |
|
|
|
uncompressed = port::Zlib_Uncompress( |
|
|
|
uncompressed = Zlib_Uncompress(compressed.data(), compressed.size(), |
|
|
|
compressed.data(), compressed.size(), &decompress_size); |
|
|
|
&decompress_size); |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kBZip2Compression: |
|
|
|
case rocksdb::kBZip2Compression: |
|
|
|
uncompressed = port::BZip2_Uncompress( |
|
|
|
uncompressed = BZip2_Uncompress(compressed.data(), compressed.size(), |
|
|
|
compressed.data(), compressed.size(), &decompress_size); |
|
|
|
&decompress_size); |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kLZ4Compression: |
|
|
|
case rocksdb::kLZ4Compression: |
|
|
|
uncompressed = port::LZ4_Uncompress( |
|
|
|
uncompressed = LZ4_Uncompress(compressed.data(), compressed.size(), |
|
|
|
compressed.data(), compressed.size(), &decompress_size); |
|
|
|
&decompress_size); |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
break; |
|
|
|
break; |
|
|
|
case rocksdb::kLZ4HCCompression: |
|
|
|
case rocksdb::kLZ4HCCompression: |
|
|
|
uncompressed = port::LZ4_Uncompress( |
|
|
|
uncompressed = LZ4_Uncompress(compressed.data(), compressed.size(), |
|
|
|
compressed.data(), compressed.size(), &decompress_size); |
|
|
|
&decompress_size); |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
ok = uncompressed != nullptr; |
|
|
|
break; |
|
|
|
break; |
|
|
|
default: |
|
|
|
default: |
|
|
|