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:
Zhongyi Xie 2019-07-15 11:39:18 -07:00 committed by Facebook Github Bot
parent f064d74e45
commit b0259e45e0

View File

@ -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
} }