@ -15,6 +15,7 @@
# include <inttypes.h>
# include <inttypes.h>
# include <string>
# include <string>
# include <algorithm>
# include <algorithm>
# include <utility>
# include <vector>
# include <vector>
# include "db/column_family.h"
# include "db/column_family.h"
@ -81,7 +82,21 @@ void PrintLevelStats(char* buf, size_t len, const std::string& name,
stats . count = = 0 ? 0 : stats . micros / kMicrosInSec / stats . count ,
stats . count = = 0 ? 0 : stats . micros / kMicrosInSec / stats . count ,
num_input_records . c_str ( ) , num_dropped_records . c_str ( ) ) ;
num_input_records . c_str ( ) , num_dropped_records . c_str ( ) ) ;
}
}
// Assumes that trailing numbers represent an optional argument. This requires
// property names to not end with numbers.
std : : pair < Slice , Slice > GetPropertyNameAndArg ( const Slice & property ) {
Slice name = property , arg = property ;
size_t sfx_len = 0 ;
while ( sfx_len < property . size ( ) & &
isdigit ( property [ property . size ( ) - sfx_len - 1 ] ) ) {
+ + sfx_len ;
}
name . remove_suffix ( sfx_len ) ;
arg . remove_prefix ( property . size ( ) - sfx_len ) ;
return { name , arg } ;
}
}
} // anonymous namespace
static const std : : string rocksdb_prefix = " rocksdb. " ;
static const std : : string rocksdb_prefix = " rocksdb. " ;
@ -188,125 +203,111 @@ const std::string DB::Properties::kAggregatedTableProperties =
const std : : string DB : : Properties : : kAggregatedTablePropertiesAtLevel =
const std : : string DB : : Properties : : kAggregatedTablePropertiesAtLevel =
rocksdb_prefix + aggregated_table_properties_at_level ;
rocksdb_prefix + aggregated_table_properties_at_level ;
DBPropertyType GetPropertyType ( const Slice & property , bool * is_int_property ,
const std : : unordered_map < std : : string ,
bool * need_out_of_mutex ) {
DBPropertyInfo > InternalStats : : ppt_name_to_info = {
assert ( is_int_property ! = nullptr ) ;
{ DB : : Properties : : kNumFilesAtLevelPrefix ,
assert ( need_out_of_mutex ! = nullptr ) ;
{ false , & InternalStats : : HandleNumFilesAtLevel , nullptr } } ,
Slice in = property ;
{ DB : : Properties : : kLevelStats ,
Slice prefix ( rocksdb_prefix ) ;
{ false , & InternalStats : : HandleLevelStats , nullptr } } ,
* need_out_of_mutex = false ;
{ DB : : Properties : : kStats , { false , & InternalStats : : HandleStats , nullptr } } ,
* is_int_property = false ;
{ DB : : Properties : : kCFStats , { false , & InternalStats : : HandleCFStats , nullptr } } ,
if ( ! in . starts_with ( prefix ) ) {
{ DB : : Properties : : kDBStats , { false , & InternalStats : : HandleDBStats , nullptr } } ,
return kUnknown ;
{ DB : : Properties : : kSSTables ,
}
{ false , & InternalStats : : HandleSsTables , nullptr } } ,
in . remove_prefix ( prefix . size ( ) ) ;
{ DB : : Properties : : kAggregatedTableProperties ,
{ false , & InternalStats : : HandleAggregatedTableProperties , nullptr } } ,
if ( in . starts_with ( num_files_at_level_prefix ) ) {
{ DB : : Properties : : kAggregatedTablePropertiesAtLevel ,
return kNumFilesAtLevel ;
{ false , & InternalStats : : HandleAggregatedTablePropertiesAtLevel , nullptr } } ,
} else if ( in = = levelstats ) {
{ DB : : Properties : : kNumImmutableMemTable ,
return kLevelStats ;
{ false , nullptr , & InternalStats : : HandleNumImmutableMemTable } } ,
} else if ( in = = allstats ) {
{ DB : : Properties : : kNumImmutableMemTableFlushed ,
return kStats ;
{ false , nullptr , & InternalStats : : HandleNumImmutableMemTableFlushed } } ,
} else if ( in = = cfstats ) {
{ DB : : Properties : : kMemTableFlushPending ,
return kCFStats ;
{ false , nullptr , & InternalStats : : HandleMemTableFlushPending } } ,
} else if ( in = = dbstats ) {
{ DB : : Properties : : kCompactionPending ,
return kDBStats ;
{ false , nullptr , & InternalStats : : HandleCompactionPending } } ,
} else if ( in = = sstables ) {
{ DB : : Properties : : kBackgroundErrors ,
return kSsTables ;
{ false , nullptr , & InternalStats : : HandleBackgroundErrors } } ,
} else if ( in = = aggregated_table_properties ) {
{ DB : : Properties : : kCurSizeActiveMemTable ,
return kAggregatedTableProperties ;
{ false , nullptr , & InternalStats : : HandleCurSizeActiveMemTable } } ,
} else if ( in . starts_with ( aggregated_table_properties_at_level ) ) {
{ DB : : Properties : : kCurSizeAllMemTables ,
return kAggregatedTablePropertiesAtLevel ;
{ false , nullptr , & InternalStats : : HandleCurSizeAllMemTables } } ,
}
{ DB : : Properties : : kSizeAllMemTables ,
{ false , nullptr , & InternalStats : : HandleSizeAllMemTables } } ,
* is_int_property = true ;
{ DB : : Properties : : kNumEntriesActiveMemTable ,
if ( in = = num_immutable_mem_table ) {
{ false , nullptr , & InternalStats : : HandleNumEntriesActiveMemTable } } ,
return kNumImmutableMemTable ;
{ DB : : Properties : : kNumEntriesImmMemTables ,
} else if ( in = = num_immutable_mem_table_flushed ) {
{ false , nullptr , & InternalStats : : HandleNumEntriesImmMemTables } } ,
return kNumImmutableMemTableFlushed ;
{ DB : : Properties : : kNumDeletesActiveMemTable ,
} else if ( in = = mem_table_flush_pending ) {
{ false , nullptr , & InternalStats : : HandleNumDeletesActiveMemTable } } ,
return kMemtableFlushPending ;
{ DB : : Properties : : kNumDeletesImmMemTables ,
} else if ( in = = compaction_pending ) {
{ false , nullptr , & InternalStats : : HandleNumDeletesImmMemTables } } ,
return kCompactionPending ;
{ DB : : Properties : : kEstimateNumKeys ,
} else if ( in = = background_errors ) {
{ false , nullptr , & InternalStats : : HandleEstimateNumKeys } } ,
return kBackgroundErrors ;
{ DB : : Properties : : kEstimateTableReadersMem ,
} else if ( in = = cur_size_active_mem_table ) {
{ true , nullptr , & InternalStats : : HandleEstimateTableReadersMem } } ,
return kCurSizeActiveMemTable ;
{ DB : : Properties : : kIsFileDeletionsEnabled ,
} else if ( in = = cur_size_all_mem_tables ) {
{ false , nullptr , & InternalStats : : HandleIsFileDeletionsEnabled } } ,
return kCurSizeAllMemTables ;
{ DB : : Properties : : kNumSnapshots ,
} else if ( in = = size_all_mem_tables ) {
{ false , nullptr , & InternalStats : : HandleNumSnapshots } } ,
return kSizeAllMemTables ;
{ DB : : Properties : : kOldestSnapshotTime ,
} else if ( in = = num_entries_active_mem_table ) {
{ false , nullptr , & InternalStats : : HandleOldestSnapshotTime } } ,
return kNumEntriesInMutableMemtable ;
{ DB : : Properties : : kNumLiveVersions ,
} else if ( in = = num_entries_imm_mem_tables ) {
{ false , nullptr , & InternalStats : : HandleNumLiveVersions } } ,
return kNumEntriesInImmutableMemtable ;
{ DB : : Properties : : kEstimateLiveDataSize ,
} else if ( in = = num_deletes_active_mem_table ) {
{ true , nullptr , & InternalStats : : HandleEstimateLiveDataSize } } ,
return kNumDeletesInMutableMemtable ;
{ DB : : Properties : : kBaseLevel ,
} else if ( in = = num_deletes_imm_mem_tables ) {
{ false , nullptr , & InternalStats : : HandleBaseLevel } } ,
return kNumDeletesInImmutableMemtable ;
{ DB : : Properties : : kTotalSstFilesSize ,
} else if ( in = = estimate_num_keys ) {
{ false , nullptr , & InternalStats : : HandleTotalSstFilesSize } } ,
return kEstimatedNumKeys ;
{ DB : : Properties : : kEstimatePendingCompactionBytes ,
} else if ( in = = estimate_table_readers_mem ) {
{ false , nullptr , & InternalStats : : HandleEstimatePendingCompactionBytes } } ,
* need_out_of_mutex = true ;
{ DB : : Properties : : kNumRunningFlushes ,
return kEstimatedUsageByTableReaders ;
{ false , nullptr , & InternalStats : : HandleNumRunningFlushes } } ,
} else if ( in = = is_file_deletions_enabled ) {
{ DB : : Properties : : kNumRunningCompactions ,
return kIsFileDeletionEnabled ;
{ false , nullptr , & InternalStats : : HandleNumRunningCompactions } } ,
} else if ( in = = num_snapshots ) {
} ;
return kNumSnapshots ;
} else if ( in = = oldest_snapshot_time ) {
const DBPropertyInfo * GetPropertyInfo ( const Slice & property ) {
return kOldestSnapshotTime ;
std : : string ppt_name = GetPropertyNameAndArg ( property ) . first . ToString ( ) ;
} else if ( in = = num_live_versions ) {
auto ppt_info_iter = InternalStats : : ppt_name_to_info . find ( ppt_name ) ;
return kNumLiveVersions ;
if ( ppt_info_iter = = InternalStats : : ppt_name_to_info . end ( ) ) {
} else if ( in = = estimate_live_data_size ) {
return nullptr ;
* need_out_of_mutex = true ;
}
return kEstimateLiveDataSize ;
return & ppt_info_iter - > second ;
} else if ( in = = base_level ) {
}
return kBaseLevel ;
} else if ( in = = total_sst_files_size ) {
bool InternalStats : : GetStringProperty ( const DBPropertyInfo & property_info ,
return kTotalSstFilesSize ;
const Slice & property ,
} else if ( in = = estimate_pending_comp_bytes ) {
std : : string * value ) {
return kEstimatePendingCompactionBytes ;
} else if ( in = = num_running_flushes ) {
return kNumRunningFlushes ;
} else if ( in = = num_running_compactions ) {
return kNumRunningCompactions ;
}
return kUnknown ;
}
bool InternalStats : : GetIntPropertyOutOfMutex ( DBPropertyType property_type ,
Version * version ,
uint64_t * value ) const {
assert ( value ! = nullptr ) ;
assert ( value ! = nullptr ) ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
assert ( property_info . handle_string ! = nullptr ) ;
Slice arg = GetPropertyNameAndArg ( property ) . second ;
switch ( property_type ) {
return ( this - > * ( property_info . handle_string ) ) ( value , arg ) ;
case kEstimatedUsageByTableReaders :
* value = ( version = = nullptr ) ?
0 : version - > GetMemoryUsageByTableReaders ( ) ;
return true ;
case kEstimateLiveDataSize :
* value = vstorage - > EstimateLiveDataSize ( ) ;
return true ;
default :
return false ;
}
}
bool InternalStats : : GetIntProperty ( const DBPropertyInfo & property_info ,
uint64_t * value , DBImpl * db ) {
assert ( value ! = nullptr ) ;
assert ( property_info . handle_int ! = nullptr & &
! property_info . need_out_of_mutex ) ;
db - > mutex_ . AssertHeld ( ) ;
return ( this - > * ( property_info . handle_int ) ) ( value , db , nullptr /* version */ ) ;
}
}
bool InternalStats : : GetStringProperty ( DBPropertyType property_type ,
bool InternalStats : : GetIntPropertyOutOfMutex (
const Slice & property ,
const DBPropertyInfo & property_info , Version * version , uint64_t * value ) {
std : : string * value ) {
assert ( value ! = nullptr ) ;
assert ( value ! = nullptr ) ;
auto * current = cfd_ - > current ( ) ;
assert ( property_info . handle_int ! = nullptr & &
const auto * vstorage = current - > storage_info ( ) ;
property_info . need_out_of_mutex ) ;
Slice in = property ;
return ( this - > * ( property_info . handle_int ) ) ( value , nullptr /* db */ , version ) ;
}
switch ( property_type ) {
bool InternalStats : : HandleNumFilesAtLevel ( std : : string * value , Slice suffix ) {
case kNumFilesAtLevel : {
in . remove_prefix ( strlen ( " rocksdb.num-files-at-level " ) ) ;
uint64_t level ;
uint64_t level ;
bool ok = ConsumeDecimalNumber ( & in , & level ) & & in . empty ( ) ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
if ( ! ok | | ( int ) level > = number_levels_ ) {
bool ok = ConsumeDecimalNumber ( & suffix , & level ) & & suffix . empty ( ) ;
if ( ! ok | | static_cast < int > ( level ) > = number_levels_ ) {
return false ;
return false ;
} else {
} else {
char buf [ 100 ] ;
char buf [ 100 ] ;
@ -316,8 +317,10 @@ bool InternalStats::GetStringProperty(DBPropertyType property_type,
return true ;
return true ;
}
}
}
}
case kLevelStats : {
bool InternalStats : : HandleLevelStats ( std : : string * value , Slice suffix ) {
char buf [ 1000 ] ;
char buf [ 1000 ] ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
snprintf ( buf , sizeof ( buf ) ,
snprintf ( buf , sizeof ( buf ) ,
" Level Files Size(MB) \n "
" Level Files Size(MB) \n "
" -------------------- \n " ) ;
" -------------------- \n " ) ;
@ -331,27 +334,35 @@ bool InternalStats::GetStringProperty(DBPropertyType property_type,
}
}
return true ;
return true ;
}
}
case kStats : {
if ( ! GetStringProperty ( kCFStats , DB : : Properties : : kCFStats , value ) ) {
bool InternalStats : : HandleStats ( std : : string * value , Slice suffix ) {
if ( ! HandleCFStats ( value , suffix ) ) {
return false ;
return false ;
}
}
if ( ! GetStringProperty ( kDBStats , DB : : Properties : : kDBStats , value ) ) {
if ( ! HandleDBStats ( value , suffix ) ) {
return false ;
return false ;
}
}
return true ;
return true ;
}
}
case kCFStats : {
bool InternalStats : : HandleCFStats ( std : : string * value , Slice suffix ) {
DumpCFStats ( value ) ;
DumpCFStats ( value ) ;
return true ;
return true ;
}
}
case kDBStats : {
bool InternalStats : : HandleDBStats ( std : : string * value , Slice suffix ) {
DumpDBStats ( value ) ;
DumpDBStats ( value ) ;
return true ;
return true ;
}
}
case kSsTables :
bool InternalStats : : HandleSsTables ( std : : string * value , Slice suffix ) {
auto * current = cfd_ - > current ( ) ;
* value = current - > DebugString ( ) ;
* value = current - > DebugString ( ) ;
return true ;
return true ;
case kAggregatedTableProperties : {
}
bool InternalStats : : HandleAggregatedTableProperties ( std : : string * value ,
Slice suffix ) {
std : : shared_ptr < const TableProperties > tp ;
std : : shared_ptr < const TableProperties > tp ;
auto s = cfd_ - > current ( ) - > GetAggregatedTableProperties ( & tp ) ;
auto s = cfd_ - > current ( ) - > GetAggregatedTableProperties ( & tp ) ;
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
@ -360,11 +371,11 @@ bool InternalStats::GetStringProperty(DBPropertyType property_type,
* value = tp - > ToString ( ) ;
* value = tp - > ToString ( ) ;
return true ;
return true ;
}
}
case kAggregatedTablePropertiesAtLevel : {
in . remove_prefix (
bool InternalStats : : HandleAggregatedTablePropertiesAtLevel ( std : : string * value ,
DB : : Properties : : kAggregatedTablePropertiesAtLevel . length ( ) ) ;
Slice suffix ) {
uint64_t level ;
uint64_t level ;
bool ok = ConsumeDecimalNumber ( & in , & level ) & & in . empty ( ) ;
bool ok = ConsumeDecimalNumber ( & suffix , & level ) & & suffix . empty ( ) ;
if ( ! ok | | static_cast < int > ( level ) > = number_levels_ ) {
if ( ! ok | | static_cast < int > ( level ) > = number_levels_ ) {
return false ;
return false ;
}
}
@ -377,74 +388,110 @@ bool InternalStats::GetStringProperty(DBPropertyType property_type,
* value = tp - > ToString ( ) ;
* value = tp - > ToString ( ) ;
return true ;
return true ;
}
}
default :
return false ;
}
}
bool InternalStats : : GetIntProperty ( DBPropertyType property_type ,
uint64_t * value , DBImpl * db ) const {
db - > mutex_ . AssertHeld ( ) ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
switch ( property_type ) {
bool InternalStats : : HandleNumImmutableMemTable ( uint64_t * value , DBImpl * db ,
case kNumImmutableMemTable :
Version * version ) {
* value = cfd_ - > imm ( ) - > NumNotFlushed ( ) ;
* value = cfd_ - > imm ( ) - > NumNotFlushed ( ) ;
return true ;
return true ;
case kNumImmutableMemTableFlushed :
}
bool InternalStats : : HandleNumImmutableMemTableFlushed ( uint64_t * value ,
DBImpl * db ,
Version * version ) {
* value = cfd_ - > imm ( ) - > NumFlushed ( ) ;
* value = cfd_ - > imm ( ) - > NumFlushed ( ) ;
return true ;
return true ;
case kMemtableFlushPending :
}
bool InternalStats : : HandleMemTableFlushPending ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Return number of mem tables that are ready to flush (made immutable)
// Return number of mem tables that are ready to flush (made immutable)
* value = ( cfd_ - > imm ( ) - > IsFlushPending ( ) ? 1 : 0 ) ;
* value = ( cfd_ - > imm ( ) - > IsFlushPending ( ) ? 1 : 0 ) ;
return true ;
return true ;
case kNumRunningFlushes :
}
bool InternalStats : : HandleNumRunningFlushes ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = db - > num_running_flushes ( ) ;
* value = db - > num_running_flushes ( ) ;
return true ;
return true ;
case kCompactionPending :
}
bool InternalStats : : HandleCompactionPending ( uint64_t * value , DBImpl * db ,
Version * version ) {
// 1 if the system already determines at least one compaction is needed.
// 1 if the system already determines at least one compaction is needed.
// 0 otherwise,
// 0 otherwise,
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = ( cfd_ - > compaction_picker ( ) - > NeedsCompaction ( vstorage ) ? 1 : 0 ) ;
* value = ( cfd_ - > compaction_picker ( ) - > NeedsCompaction ( vstorage ) ? 1 : 0 ) ;
return true ;
return true ;
case kNumRunningCompactions :
}
bool InternalStats : : HandleNumRunningCompactions ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = db - > num_running_compactions_ ;
* value = db - > num_running_compactions_ ;
return true ;
return true ;
case kBackgroundErrors :
}
bool InternalStats : : HandleBackgroundErrors ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Accumulated number of errors in background flushes or compactions.
// Accumulated number of errors in background flushes or compactions.
* value = GetBackgroundErrorCount ( ) ;
* value = GetBackgroundErrorCount ( ) ;
return true ;
return true ;
case kCurSizeActiveMemTable :
}
bool InternalStats : : HandleCurSizeActiveMemTable ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Current size of the active memtable
// Current size of the active memtable
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) ;
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) ;
return true ;
return true ;
case kCurSizeAllMemTables :
}
bool InternalStats : : HandleCurSizeAllMemTables ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Current size of the active memtable + immutable memtables
// Current size of the active memtable + immutable memtables
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
cfd_ - > imm ( ) - > ApproximateUnflushedMemTablesMemoryUsage ( ) ;
cfd_ - > imm ( ) - > ApproximateUnflushedMemTablesMemoryUsage ( ) ;
return true ;
return true ;
case kSizeAllMemTables :
}
bool InternalStats : : HandleSizeAllMemTables ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
cfd_ - > imm ( ) - > ApproximateMemoryUsage ( ) ;
cfd_ - > imm ( ) - > ApproximateMemoryUsage ( ) ;
return true ;
return true ;
case kNumEntriesInMutableMemtable :
}
bool InternalStats : : HandleNumEntriesActiveMemTable ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Current number of entires in the active memtable
// Current number of entires in the active memtable
* value = cfd_ - > mem ( ) - > num_entries ( ) ;
* value = cfd_ - > mem ( ) - > num_entries ( ) ;
return true ;
return true ;
case kNumEntriesInImmutableMemtable :
}
bool InternalStats : : HandleNumEntriesImmMemTables ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Current number of entries in the immutable memtables
// Current number of entries in the immutable memtables
* value = cfd_ - > imm ( ) - > current ( ) - > GetTotalNumEntries ( ) ;
* value = cfd_ - > imm ( ) - > current ( ) - > GetTotalNumEntries ( ) ;
return true ;
return true ;
case kNumDeletesInMutableMemtable :
}
bool InternalStats : : HandleNumDeletesActiveMemTable ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Current number of entires in the active memtable
// Current number of entires in the active memtable
* value = cfd_ - > mem ( ) - > num_deletes ( ) ;
* value = cfd_ - > mem ( ) - > num_deletes ( ) ;
return true ;
return true ;
case kNumDeletesInImmutableMemtable :
}
bool InternalStats : : HandleNumDeletesImmMemTables ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Current number of entries in the immutable memtables
// Current number of entries in the immutable memtables
* value = cfd_ - > imm ( ) - > current ( ) - > GetTotalNumDeletes ( ) ;
* value = cfd_ - > imm ( ) - > current ( ) - > GetTotalNumDeletes ( ) ;
return true ;
return true ;
case kEstimatedNumKeys :
}
bool InternalStats : : HandleEstimateNumKeys ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Estimate number of entries in the column family:
// Estimate number of entries in the column family:
// Use estimated entries in tables + total entries in memtables.
// Use estimated entries in tables + total entries in memtables.
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = cfd_ - > mem ( ) - > num_entries ( ) +
* value = cfd_ - > mem ( ) - > num_entries ( ) +
cfd_ - > imm ( ) - > current ( ) - > GetTotalNumEntries ( ) -
cfd_ - > imm ( ) - > current ( ) - > GetTotalNumEntries ( ) -
( cfd_ - > mem ( ) - > num_deletes ( ) +
( cfd_ - > mem ( ) - > num_deletes ( ) +
@ -452,30 +499,64 @@ bool InternalStats::GetIntProperty(DBPropertyType property_type,
2 +
2 +
vstorage - > GetEstimatedActiveKeys ( ) ;
vstorage - > GetEstimatedActiveKeys ( ) ;
return true ;
return true ;
case kNumSnapshots :
}
bool InternalStats : : HandleNumSnapshots ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = db - > snapshots ( ) . count ( ) ;
* value = db - > snapshots ( ) . count ( ) ;
return true ;
return true ;
case kOldestSnapshotTime :
}
bool InternalStats : : HandleOldestSnapshotTime ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = static_cast < uint64_t > ( db - > snapshots ( ) . GetOldestSnapshotTime ( ) ) ;
* value = static_cast < uint64_t > ( db - > snapshots ( ) . GetOldestSnapshotTime ( ) ) ;
return true ;
return true ;
case kNumLiveVersions :
}
bool InternalStats : : HandleNumLiveVersions ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = cfd_ - > GetNumLiveVersions ( ) ;
* value = cfd_ - > GetNumLiveVersions ( ) ;
return true ;
return true ;
case kIsFileDeletionEnabled :
}
bool InternalStats : : HandleIsFileDeletionsEnabled ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = db - > IsFileDeletionsEnabled ( ) ;
* value = db - > IsFileDeletionsEnabled ( ) ;
return true ;
return true ;
case kBaseLevel :
}
bool InternalStats : : HandleBaseLevel ( uint64_t * value , DBImpl * db ,
Version * version ) {
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = vstorage - > base_level ( ) ;
* value = vstorage - > base_level ( ) ;
return true ;
return true ;
case kTotalSstFilesSize :
}
bool InternalStats : : HandleTotalSstFilesSize ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = cfd_ - > GetTotalSstFilesSize ( ) ;
* value = cfd_ - > GetTotalSstFilesSize ( ) ;
return true ;
return true ;
case kEstimatePendingCompactionBytes :
}
bool InternalStats : : HandleEstimatePendingCompactionBytes ( uint64_t * value ,
DBImpl * db ,
Version * version ) {
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = vstorage - > estimated_compaction_needed_bytes ( ) ;
* value = vstorage - > estimated_compaction_needed_bytes ( ) ;
return true ;
return true ;
default :
return false ;
}
}
bool InternalStats : : HandleEstimateTableReadersMem ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = ( version = = nullptr ) ? 0 : version - > GetMemoryUsageByTableReaders ( ) ;
return true ;
}
bool InternalStats : : HandleEstimateLiveDataSize ( uint64_t * value , DBImpl * db ,
Version * version ) {
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = vstorage - > EstimateLiveDataSize ( ) ;
return true ;
}
}
void InternalStats : : DumpDBStats ( std : : string * value ) {
void InternalStats : : DumpDBStats ( std : : string * value ) {
@ -760,10 +841,7 @@ void InternalStats::DumpCFStats(std::string* value) {
# else
# else
DBPropertyType GetPropertyType ( const Slice & property , bool * is_int_property ,
const DBPropertyInfo * GetPropertyInfo ( const Slice & property ) { return nullptr ; }
bool * need_out_of_mutex ) {
return kUnknown ;
}
# endif // !ROCKSDB_LITE
# endif // !ROCKSDB_LITE