| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- // Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
- // This source code is licensed under both the GPLv2 (found in the
- // COPYING file in the root directory) and Apache 2.0 License
- // (found in the LICENSE.Apache file in the root directory).
- // Copyright (c) 2011 The LevelDB Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style license that can be
- // found in the LICENSE file. See the AUTHORS file for names of contributors.
- #pragma once
- #include "db/db_impl/db_impl.h"
- #include "rocksdb/stats_history.h"
- namespace ROCKSDB_NAMESPACE {
- extern const std::string kFormatVersionKeyString;
- extern const std::string kCompatibleVersionKeyString;
- extern const uint64_t kStatsCFCurrentFormatVersion;
- extern const uint64_t kStatsCFCompatibleFormatVersion;
- enum StatsVersionKeyType : uint32_t {
- kFormatVersion = 1,
- kCompatibleVersion = 2,
- kKeyTypeMax = 3
- };
- // Read the version number from persitent stats cf depending on type provided
- // stores the version number in `*version_number`
- // returns Status::OK() on success, or other status code on failure
- Status DecodePersistentStatsVersionNumber(DBImpl* db, StatsVersionKeyType type,
- uint64_t* version_number);
- // Encode timestamp and stats key into buf
- // Format: timestamp(10 digit) + '#' + key
- // Total length of encoded key will be capped at 100 bytes
- int EncodePersistentStatsKey(uint64_t timestamp, const std::string& key,
- int size, char* buf);
- void OptimizeForPersistentStats(ColumnFamilyOptions* cfo);
- class PersistentStatsHistoryIterator final : public StatsHistoryIterator {
- public:
- PersistentStatsHistoryIterator(uint64_t start_time, uint64_t end_time,
- DBImpl* db_impl)
- : time_(0),
- start_time_(start_time),
- end_time_(end_time),
- valid_(true),
- db_impl_(db_impl) {
- AdvanceIteratorByTime(start_time_, end_time_);
- }
- ~PersistentStatsHistoryIterator() override;
- bool Valid() const override;
- Status status() const override;
- void Next() override;
- uint64_t GetStatsTime() const override;
- const std::map<std::string, uint64_t>& GetStatsMap() const override;
- private:
- // advance the iterator to the next stats history record with timestamp
- // between [start_time, end_time)
- void AdvanceIteratorByTime(uint64_t start_time, uint64_t end_time);
- // No copying allowed
- PersistentStatsHistoryIterator(const PersistentStatsHistoryIterator&) =
- delete;
- void operator=(const PersistentStatsHistoryIterator&) = delete;
- PersistentStatsHistoryIterator(PersistentStatsHistoryIterator&&) = delete;
- PersistentStatsHistoryIterator& operator=(PersistentStatsHistoryIterator&&) =
- delete;
- uint64_t time_;
- uint64_t start_time_;
- uint64_t end_time_;
- std::map<std::string, uint64_t> stats_map_;
- Status status_;
- bool valid_;
- DBImpl* db_impl_;
- };
- } // namespace ROCKSDB_NAMESPACE
|