add more tracing for stats history (#5566)
Summary: Sample info log output from db_bench: In-memory: ``` 2019/07/12-21:39:19.478490 7fa01b3f5700 [_impl/db_impl.cc:702] ------- PERSISTING STATS ------- 2019/07/12-21:39:19.478633 7fa01b3f5700 [_impl/db_impl.cc:753] Storing 145 stats with timestamp 1562992759 to in-memory stats history 2019/07/12-21:39:19.478670 7fa01b3f5700 [_impl/db_impl.cc:766] [Pre-GC] In-memory stats history size: 1051218 bytes, slice count: 103 2019/07/12-21:39:19.478704 7fa01b3f5700 [_impl/db_impl.cc:775] [Post-GC] In-memory stats history size: 1051218 bytes, slice count: 102 ``` On-disk: ``` 2019/07/12-21:48:53.862548 7f24943f5700 [_impl/db_impl.cc:702] ------- PERSISTING STATS ------- 2019/07/12-21:48:53.862553 7f24943f5700 [_impl/db_impl.cc:709] Reading 145 stats from statistics 2019/07/12-21:48:53.862852 7f24943f5700 [_impl/db_impl.cc:737] Writing 145 stats with timestamp 1562993333 to persistent stats CF succeeded ``` ``` 2019/07/12-21:48:51.861711 7f24943f5700 [_impl/db_impl.cc:702] ------- PERSISTING STATS ------- 2019/07/12-21:48:51.861729 7f24943f5700 [_impl/db_impl.cc:709] Reading 145 stats from statistics 2019/07/12-21:48:51.861921 7f24943f5700 [_impl/db_impl.cc:732] Writing to persistent stats CF failed -- Result incomplete: Write stall ... 2019/07/12-21:48:51.873032 7f2494bf6700 [WARN] [lumn_family.cc:749] [default] Stopping writes because we have 2 immutable memtables (waiting for flush), max_write_buffer_number is set to 2 ``` Pull Request resolved: https://github.com/facebook/rocksdb/pull/5566 Differential Revision: D16258187 Pulled By: miasantreble fbshipit-source-id: 292497099b941418590ed4312411bee36e244dc5
This commit is contained in:
parent
f064d74e45
commit
b0259e45e0
@ -14,6 +14,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <cinttypes>
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <set>
|
#include <set>
|
||||||
@ -697,10 +698,15 @@ void DBImpl::PersistStats() {
|
|||||||
if (!statistics->getTickerMap(&stats_map)) {
|
if (!statistics->getTickerMap(&stats_map)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
|
"------- PERSISTING STATS -------");
|
||||||
|
|
||||||
if (immutable_db_options_.persist_stats_to_disk) {
|
if (immutable_db_options_.persist_stats_to_disk) {
|
||||||
WriteBatch batch;
|
WriteBatch batch;
|
||||||
if (stats_slice_initialized_) {
|
if (stats_slice_initialized_) {
|
||||||
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
|
"Reading %" ROCKSDB_PRIszt " stats from statistics\n",
|
||||||
|
stats_slice_.size());
|
||||||
for (const auto& stat : stats_map) {
|
for (const auto& stat : stats_map) {
|
||||||
char key[100];
|
char key[100];
|
||||||
int length =
|
int length =
|
||||||
@ -722,8 +728,13 @@ void DBImpl::PersistStats() {
|
|||||||
Status s = Write(wo, &batch);
|
Status s = Write(wo, &batch);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
"Writing to persistent stats CF failed -- %s\n",
|
"Writing to persistent stats CF failed -- %s",
|
||||||
s.ToString().c_str());
|
s.ToString().c_str());
|
||||||
|
} else {
|
||||||
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
|
"Writing %" ROCKSDB_PRIszt " stats with timestamp %" PRIu64
|
||||||
|
" to persistent stats CF succeeded",
|
||||||
|
stats_slice_.size(), now_seconds);
|
||||||
}
|
}
|
||||||
// TODO(Zhongyi): add purging for persisted data
|
// TODO(Zhongyi): add purging for persisted data
|
||||||
} else {
|
} else {
|
||||||
@ -736,6 +747,10 @@ void DBImpl::PersistStats() {
|
|||||||
stats_delta[stat.first] = stat.second - stats_slice_[stat.first];
|
stats_delta[stat.first] = stat.second - stats_slice_[stat.first];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
|
"Storing %" ROCKSDB_PRIszt " stats with timestamp %" PRIu64
|
||||||
|
" to in-memory stats history",
|
||||||
|
stats_slice_.size(), now_seconds);
|
||||||
stats_history_[now_seconds] = stats_delta;
|
stats_history_[now_seconds] = stats_delta;
|
||||||
}
|
}
|
||||||
stats_slice_initialized_ = true;
|
stats_slice_initialized_ = true;
|
||||||
@ -743,15 +758,22 @@ void DBImpl::PersistStats() {
|
|||||||
TEST_SYNC_POINT("DBImpl::PersistStats:StatsCopied");
|
TEST_SYNC_POINT("DBImpl::PersistStats:StatsCopied");
|
||||||
|
|
||||||
// delete older stats snapshots to control memory consumption
|
// delete older stats snapshots to control memory consumption
|
||||||
bool purge_needed =
|
size_t stats_history_size = EstimateInMemoryStatsHistorySize();
|
||||||
EstimateInMemoryStatsHistorySize() > stats_history_size_limit;
|
bool purge_needed = stats_history_size > stats_history_size_limit;
|
||||||
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
|
"[Pre-GC] In-memory stats history size: %" ROCKSDB_PRIszt
|
||||||
|
" bytes, slice count: %" ROCKSDB_PRIszt,
|
||||||
|
stats_history_size, stats_history_.size());
|
||||||
while (purge_needed && !stats_history_.empty()) {
|
while (purge_needed && !stats_history_.empty()) {
|
||||||
stats_history_.erase(stats_history_.begin());
|
stats_history_.erase(stats_history_.begin());
|
||||||
purge_needed =
|
purge_needed =
|
||||||
EstimateInMemoryStatsHistorySize() > stats_history_size_limit;
|
EstimateInMemoryStatsHistorySize() > stats_history_size_limit;
|
||||||
}
|
}
|
||||||
|
ROCKS_LOG_INFO(immutable_db_options_.info_log,
|
||||||
|
"[Post-GC] In-memory stats history size: %" ROCKSDB_PRIszt
|
||||||
|
" bytes, slice count: %" ROCKSDB_PRIszt,
|
||||||
|
stats_history_size, stats_history_.size());
|
||||||
}
|
}
|
||||||
// TODO: persist stats to disk
|
|
||||||
#endif // !ROCKSDB_LITE
|
#endif // !ROCKSDB_LITE
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user