0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-13 16:33:53 +01:00

ircd:Ⓜ️:db: Fix accounting for index compression.

Revert 1051e740cc.
This commit is contained in:
Jason Volk 2020-09-30 16:24:15 -07:00
parent 28c4baf2b2
commit fecd009ffb
4 changed files with 57 additions and 34 deletions

View file

@ -41,6 +41,7 @@ struct ircd::db::database::sst::info
uint64_t head_size {0}; // index_size + filter_size
uint64_t data_size {0};
uint64_t file_size {0}; // head_size + data_size
uint64_t meta_size {0}; // size - data_size (???)
uint64_t index_root_size {0};
uint64_t index_data_size {0};
uint64_t index_size {0}; // index_root_size + index_data_size
@ -65,6 +66,8 @@ struct ircd::db::database::sst::info
time_t oldest_key {0};
bool delta_encoding {false};
float compression_pct {0.0};
float index_compression_pct {0.0};
float blocks_compression_pct {0.0};
info(const database &, const string_view &filename);
info() = default;

View file

@ -4120,8 +4120,9 @@ ircd::db::database::sst::info::operator=(rocksdb::TableProperties &&tp)
format = std::move(tp.format_version);
cfid = std::move(tp.column_family_id);
data_size = std::move(tp.data_size);
index_data_size = std::move(tp.index_size);
index_root_size = std::move(tp.top_level_index_size);
index_data_size = std::move(tp.index_size);
index_data_size -= index_root_size;
filter_size = std::move(tp.filter_size);
keys_size = std::move(tp.raw_key_size);
values_size = std::move(tp.raw_value_size);
@ -4137,11 +4138,22 @@ ircd::db::database::sst::info::operator=(rocksdb::TableProperties &&tp)
blocks_size = keys_size + values_size;
index_size = index_data_size + index_root_size;
head_size = index_size + filter_size;
file_size = head_size + data_size;
file_size = head_size + blocks_size;
const long double _blocks_size(std::max(blocks_size, 1UL));
compression_pct = compression != "NoCompression"?
(100 - 100.0L * (data_size / _blocks_size)):
meta_size = size > data_size?
size - data_size:
0UL;
compression_pct = size?
100 - 100.0L * (size / (long double)file_size):
0.0;
index_compression_pct = index_size?
100 - 100.0L * (meta_size / (long double)index_size):
0.0;
blocks_compression_pct = data_size?
100 - 100.0L * (data_size / (long double)blocks_size):
0.0;
return *this;

View file

@ -118,7 +118,7 @@ ircd::m::dbs::desc::event_idx
size_t(event_idx__meta_block__size),
// compression
{}, // no compression
"default"s,
// compactor
{},

View file

@ -4494,70 +4494,78 @@ _print_sst_info_full(opt &out,
close_auto("name", f.name);
close_auto("directory", f.path);
close_auto("format", f.format);
close_auto("version", f.version);
close_auto("creation", timestr(f.created, ircd::localtime));
close_auto("checksum function", f.checksum_func);
close_auto("checksum value", f.checksum);
close_auto("column ID", f.cfid);
close_auto("column", f.column);
close_auto("column comparator", f.comparator);
close_auto("column merge operator", f.merge_operator);
close_auto("column prefix extractor", f.prefix_extractor);
close_size("file size", f.size);
close_auto("file creation", timestr(f.created, ircd::localtime));
close_auto("file version", f.version);
close_auto("checksum function", f.checksum_func);
close_auto("checksum value", f.checksum);
close_auto("level", f.level);
close_auto("lowest sequence", f.min_seq);
close_auto("highest sequence", f.max_seq);
close_auto("lowest key", min_key);
close_auto("highest key", max_key);
close_auto("compression", f.compression);
close_auto("delta encode", f.delta_encoding? "yes"_sv : "no"_sv);
close_auto("fixed key length", f.fixed_key_len);
close_auto("delta encode", f.delta_encoding? "yes"_sv : "no"_sv);
close_auto("compression", f.compression);
close_auto("compacting", f.compacting? "yes"_sv : "no"_sv);
close_auto("range deletes", f.range_deletes);
close_auto("", "");
close_size("size", f.file_size);
close_size("head size", f.head_size);
close_size("data size", f.data_size);
close_size("data blocks average size", f.data_size / double(f.data_blocks));
close_auto("data compression percent", 100 - 100.0L * (f.data_size / double(f.blocks_size)));
close_size("file phys size", f.size);
close_size("file virt size", f.file_size);
close_auto("file compress percent", f.compression_pct);
close_auto("", "");
close_size("file head phys size", f.meta_size);
close_size("file head virt size", f.head_size);
close_auto("file head compress percent", 100 - 100.0L * (f.meta_size / (long double)f.head_size));
close_size("index size", f.index_size);
close_size("index root size", f.index_root_size);
close_size("index head size", f.index_root_size);
close_size("index data size", f.index_data_size);
close_auto("index data blocks", f.index_parts);
close_size("index data block average size", f.index_data_size / double(f.index_parts));
close_size("index data average per-key", f.index_data_size / double(f.entries));
close_size("index data average per-block", f.index_data_size / double(f.data_blocks));
close_auto("index root percent of index", 100.0 * (f.index_root_size / double(f.index_data_size)));
close_auto("index head percent of index", 100.0 * (f.index_root_size / double(f.index_data_size)));
close_auto("index data percent of keys", 100.0 * (f.index_data_size / double(f.keys_size)));
close_auto("index data percent of values", 100.0 * (f.index_data_size / double(f.values_size)));
close_auto("index data percent of data", 100.0 * (f.index_data_size / double(f.data_size)));
close_auto("index data compress percent", f.index_compression_pct);
close_auto("", "");
if(!f.filter.empty())
{
close_auto("filter", f.filter);
close_size("filter size", f.filter_size);
close_auto("filter average per-key", f.filter_size / double(f.entries));
close_auto("filter average per-block", f.filter_size / double(f.data_blocks));
close_auto("", "");
}
close_auto("blocks", f.data_blocks);
close_size("blocks size", f.blocks_size);
close_size("blocks average size", f.blocks_size / double(f.data_blocks));
close_size("blocks phys size", f.data_size);
close_size("blocks phys average size", f.data_size / double(f.data_blocks));
close_size("blocks virt size", f.blocks_size);
close_size("blocks virt average size", f.blocks_size / double(f.data_blocks));
close_auto("blocks compress percent", f.blocks_compression_pct);
close_auto("", "");
close_auto("keys", f.entries);
close_size("keys size", f.keys_size);
close_size("keys average size", f.keys_size / double(f.entries));
close_auto("keys percent of blocks", 100.0 * (f.keys_size / double(f.blocks_size)));
close_size("keys virt size", f.keys_size);
close_size("keys virt average size", f.keys_size / double(f.entries));
close_auto("keys virt percent of blocks", 100.0 * (f.keys_size / double(f.blocks_size)));
close_auto("", "");
close_auto("values", f.entries);
close_size("values size", f.values_size);
close_size("values average size", f.values_size / double(f.entries));
close_auto("values average per-index", f.entries / double(f.index_parts));
close_auto("values average per-block", f.entries / double(f.data_blocks));
close_size("values virt size", f.values_size);
close_size("values virt average size", f.values_size / double(f.entries));
close_auto("values virt average per-index", f.entries / double(f.index_parts));
close_auto("values virt average per-block", f.entries / double(f.data_blocks));
close_auto("", "");
}