@ -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. " ;
@ -139,7 +154,7 @@ const std::string DB::Properties::kLevelStats = rocksdb_prefix + levelstats;
const std : : string DB : : Properties : : kNumImmutableMemTable =
const std : : string DB : : Properties : : kNumImmutableMemTable =
rocksdb_prefix + num_immutable_mem_table ;
rocksdb_prefix + num_immutable_mem_table ;
const std : : string DB : : Properties : : kNumImmutableMemTableFlushed =
const std : : string DB : : Properties : : kNumImmutableMemTableFlushed =
rocksdb_prefix + num_immutable_mem_table_flushed ;
rocksdb_prefix + num_immutable_mem_table_flushed ;
const std : : string DB : : Properties : : kMemTableFlushPending =
const std : : string DB : : Properties : : kMemTableFlushPending =
rocksdb_prefix + mem_table_flush_pending ;
rocksdb_prefix + mem_table_flush_pending ;
const std : : string DB : : Properties : : kCompactionPending =
const std : : string DB : : Properties : : kCompactionPending =
@ -188,294 +203,360 @@ 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 } } ,
{ DB : : Properties : : kNumEntriesActiveMemTable ,
{ false , nullptr , & InternalStats : : HandleNumEntriesActiveMemTable } } ,
{ DB : : Properties : : kNumEntriesImmMemTables ,
{ false , nullptr , & InternalStats : : HandleNumEntriesImmMemTables } } ,
{ DB : : Properties : : kNumDeletesActiveMemTable ,
{ false , nullptr , & InternalStats : : HandleNumDeletesActiveMemTable } } ,
{ DB : : Properties : : kNumDeletesImmMemTables ,
{ false , nullptr , & InternalStats : : HandleNumDeletesImmMemTables } } ,
{ DB : : Properties : : kEstimateNumKeys ,
{ false , nullptr , & InternalStats : : HandleEstimateNumKeys } } ,
{ DB : : Properties : : kEstimateTableReadersMem ,
{ true , nullptr , & InternalStats : : HandleEstimateTableReadersMem } } ,
{ DB : : Properties : : kIsFileDeletionsEnabled ,
{ false , nullptr , & InternalStats : : HandleIsFileDeletionsEnabled } } ,
{ DB : : Properties : : kNumSnapshots ,
{ false , nullptr , & InternalStats : : HandleNumSnapshots } } ,
{ DB : : Properties : : kOldestSnapshotTime ,
{ false , nullptr , & InternalStats : : HandleOldestSnapshotTime } } ,
{ DB : : Properties : : kNumLiveVersions ,
{ false , nullptr , & InternalStats : : HandleNumLiveVersions } } ,
{ DB : : Properties : : kEstimateLiveDataSize ,
{ true , nullptr , & InternalStats : : HandleEstimateLiveDataSize } } ,
{ DB : : Properties : : kBaseLevel ,
{ false , nullptr , & InternalStats : : HandleBaseLevel } } ,
{ DB : : Properties : : kTotalSstFilesSize ,
{ false , nullptr , & InternalStats : : HandleTotalSstFilesSize } } ,
{ DB : : Properties : : kEstimatePendingCompactionBytes ,
{ false , nullptr , & InternalStats : : HandleEstimatePendingCompactionBytes } } ,
{ DB : : Properties : : kNumRunningFlushes ,
{ false , nullptr , & InternalStats : : HandleNumRunningFlushes } } ,
{ DB : : Properties : : kNumRunningCompactions ,
{ false , nullptr , & InternalStats : : HandleNumRunningCompactions } } ,
} ;
const DBPropertyInfo * GetPropertyInfo ( const Slice & property ) {
std : : string ppt_name = GetPropertyNameAndArg ( property ) . first . ToString ( ) ;
auto ppt_info_iter = InternalStats : : ppt_name_to_info . find ( ppt_name ) ;
if ( ppt_info_iter = = InternalStats : : ppt_name_to_info . end ( ) ) {
return nullptr ;
}
}
return & ppt_info_iter - > second ;
}
* is_int_property = true ;
bool InternalStats : : GetStringProperty ( const DBPropertyInfo & property_info ,
if ( in = = num_immutable_mem_table ) {
const Slice & property ,
return kNumImmutableMemTable ;
std : : string * value ) {
} else if ( in = = num_immutable_mem_table_flushed ) {
assert ( value ! = nullptr ) ;
return kNumImmutableMemTableFlushed ;
assert ( property_info . handle_string ! = nullptr ) ;
} else if ( in = = mem_table_flush_pending ) {
Slice arg = GetPropertyNameAndArg ( property ) . second ;
return kMemtableFlushPending ;
return ( this - > * ( property_info . handle_string ) ) ( value , arg ) ;
} else if ( in = = compaction_pending ) {
return kCompactionPending ;
} else if ( in = = background_errors ) {
return kBackgroundErrors ;
} else if ( in = = cur_size_active_mem_table ) {
return kCurSizeActiveMemTable ;
} else if ( in = = cur_size_all_mem_tables ) {
return kCurSizeAllMemTables ;
} else if ( in = = size_all_mem_tables ) {
return kSizeAllMemTables ;
} else if ( in = = num_entries_active_mem_table ) {
return kNumEntriesInMutableMemtable ;
} else if ( in = = num_entries_imm_mem_tables ) {
return kNumEntriesInImmutableMemtable ;
} else if ( in = = num_deletes_active_mem_table ) {
return kNumDeletesInMutableMemtable ;
} else if ( in = = num_deletes_imm_mem_tables ) {
return kNumDeletesInImmutableMemtable ;
} else if ( in = = estimate_num_keys ) {
return kEstimatedNumKeys ;
} else if ( in = = estimate_table_readers_mem ) {
* need_out_of_mutex = true ;
return kEstimatedUsageByTableReaders ;
} else if ( in = = is_file_deletions_enabled ) {
return kIsFileDeletionEnabled ;
} else if ( in = = num_snapshots ) {
return kNumSnapshots ;
} else if ( in = = oldest_snapshot_time ) {
return kOldestSnapshotTime ;
} else if ( in = = num_live_versions ) {
return kNumLiveVersions ;
} else if ( in = = estimate_live_data_size ) {
* need_out_of_mutex = true ;
return kEstimateLiveDataSize ;
} else if ( in = = base_level ) {
return kBaseLevel ;
} else if ( in = = total_sst_files_size ) {
return kTotalSstFilesSize ;
} else if ( in = = estimate_pending_comp_bytes ) {
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 ,
bool InternalStats : : GetIntProperty ( const DBPropertyInfo & property_info ,
Version * version ,
uint64_t * value , DBImpl * db ) {
uint64_t * value ) const {
assert ( value ! = nullptr ) ;
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 : : GetIntPropertyOutOfMutex (
const DBPropertyInfo & property_info , Version * version , uint64_t * value ) {
assert ( value ! = nullptr ) ;
assert ( property_info . handle_int ! = nullptr & &
property_info . need_out_of_mutex ) ;
return ( this - > * ( property_info . handle_int ) ) ( value , nullptr /* db */ , version ) ;
}
bool InternalStats : : HandleNumFilesAtLevel ( std : : string * value , Slice suffix ) {
uint64_t level ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
bool ok = ConsumeDecimalNumber ( & suffix , & level ) & & suffix . empty ( ) ;
if ( ! ok | | static_cast < int > ( level ) > = number_levels_ ) {
return false ;
} else {
char buf [ 100 ] ;
snprintf ( buf , sizeof ( buf ) , " %d " ,
vstorage - > NumLevelFiles ( static_cast < int > ( level ) ) ) ;
* value = buf ;
return true ;
}
}
bool InternalStats : : HandleLevelStats ( std : : string * value , Slice suffix ) {
char buf [ 1000 ] ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
snprintf ( buf , sizeof ( buf ) ,
" Level Files Size(MB) \n "
" -------------------- \n " ) ;
value - > append ( buf ) ;
switch ( property_type ) {
for ( int level = 0 ; level < number_levels_ ; level + + ) {
case kEstimatedUsageByTableReaders :
snprintf ( buf , sizeof ( buf ) , " %3d %8d %8.0f \n " , level ,
* value = ( version = = nullptr ) ?
vstorage - > NumLevelFiles ( level ) ,
0 : version - > GetMemoryUsageByTableReaders ( ) ;
vstorage - > NumLevelBytes ( level ) / kMB ) ;
return true ;
value - > append ( buf ) ;
case kEstimateLiveDataSize :
* value = vstorage - > EstimateLiveDataSize ( ) ;
return true ;
default :
return false ;
}
}
return true ;
}
}
bool InternalStats : : GetStringProperty ( DBPropertyType property_type ,
bool InternalStats : : HandleStats ( std : : string * value , Slice suffix ) {
const Slice & property ,
if ( ! HandleCFStats ( value , suffix ) ) {
std : : string * value ) {
return false ;
assert ( value ! = nullptr ) ;
}
if ( ! HandleDBStats ( value , suffix ) ) {
return false ;
}
return true ;
}
bool InternalStats : : HandleCFStats ( std : : string * value , Slice suffix ) {
DumpCFStats ( value ) ;
return true ;
}
bool InternalStats : : HandleDBStats ( std : : string * value , Slice suffix ) {
DumpDBStats ( value ) ;
return true ;
}
bool InternalStats : : HandleSsTables ( std : : string * value , Slice suffix ) {
auto * current = cfd_ - > current ( ) ;
auto * current = cfd_ - > current ( ) ;
const auto * vstorage = current - > storage_info ( ) ;
* value = current - > DebugString ( ) ;
Slice in = property ;
return true ;
}
switch ( property_type ) {
case kNumFilesAtLevel : {
in . remove_prefix ( strlen ( " rocksdb.num-files-at-level " ) ) ;
uint64_t level ;
bool ok = ConsumeDecimalNumber ( & in , & level ) & & in . empty ( ) ;
if ( ! ok | | ( int ) level > = number_levels_ ) {
return false ;
} else {
char buf [ 100 ] ;
snprintf ( buf , sizeof ( buf ) , " %d " ,
vstorage - > NumLevelFiles ( static_cast < int > ( level ) ) ) ;
* value = buf ;
return true ;
}
}
case kLevelStats : {
char buf [ 1000 ] ;
snprintf ( buf , sizeof ( buf ) ,
" Level Files Size(MB) \n "
" -------------------- \n " ) ;
value - > append ( buf ) ;
for ( int level = 0 ; level < number_levels_ ; level + + ) {
bool InternalStats : : HandleAggregatedTableProperties ( std : : string * value ,
snprintf ( buf , sizeof ( buf ) , " %3d %8d %8.0f \n " , level ,
Slice suffix ) {
vstorage - > NumLevelFiles ( level ) ,
std : : shared_ptr < const TableProperties > tp ;
vstorage - > NumLevelBytes ( level ) / kMB ) ;
auto s = cfd_ - > current ( ) - > GetAggregatedTableProperties ( & tp ) ;
value - > append ( buf ) ;
if ( ! s . ok ( ) ) {
}
return false ;
return true ;
}
case kStats : {
if ( ! GetStringProperty ( kCFStats , DB : : Properties : : kCFStats , value ) ) {
return false ;
}
if ( ! GetStringProperty ( kDBStats , DB : : Properties : : kDBStats , value ) ) {
return false ;
}
return true ;
}
case kCFStats : {
DumpCFStats ( value ) ;
return true ;
}
case kDBStats : {
DumpDBStats ( value ) ;
return true ;
}
case kSsTables :
* value = current - > DebugString ( ) ;
return true ;
case kAggregatedTableProperties : {
std : : shared_ptr < const TableProperties > tp ;
auto s = cfd_ - > current ( ) - > GetAggregatedTableProperties ( & tp ) ;
if ( ! s . ok ( ) ) {
return false ;
}
* value = tp - > ToString ( ) ;
return true ;
}
case kAggregatedTablePropertiesAtLevel : {
in . remove_prefix (
DB : : Properties : : kAggregatedTablePropertiesAtLevel . length ( ) ) ;
uint64_t level ;
bool ok = ConsumeDecimalNumber ( & in , & level ) & & in . empty ( ) ;
if ( ! ok | | static_cast < int > ( level ) > = number_levels_ ) {
return false ;
}
std : : shared_ptr < const TableProperties > tp ;
auto s = cfd_ - > current ( ) - > GetAggregatedTableProperties (
& tp , static_cast < int > ( level ) ) ;
if ( ! s . ok ( ) ) {
return false ;
}
* value = tp - > ToString ( ) ;
return true ;
}
default :
return false ;
}
}
* value = tp - > ToString ( ) ;
return true ;
}
}
bool InternalStats : : GetIntProperty ( DBPropertyType property_type ,
bool InternalStats : : HandleAggregatedTablePropertiesAtLevel ( std : : string * value ,
uint64_t * value , DBImpl * db ) const {
Slice suffix ) {
db - > mutex_ . AssertHeld ( ) ;
uint64_t level ;
bool ok = ConsumeDecimalNumber ( & suffix , & level ) & & suffix . empty ( ) ;
if ( ! ok | | static_cast < int > ( level ) > = number_levels_ ) {
return false ;
}
std : : shared_ptr < const TableProperties > tp ;
auto s = cfd_ - > current ( ) - > GetAggregatedTableProperties (
& tp , static_cast < int > ( level ) ) ;
if ( ! s . ok ( ) ) {
return false ;
}
* value = tp - > ToString ( ) ;
return true ;
}
bool InternalStats : : HandleNumImmutableMemTable ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = cfd_ - > imm ( ) - > NumNotFlushed ( ) ;
return true ;
}
bool InternalStats : : HandleNumImmutableMemTableFlushed ( uint64_t * value ,
DBImpl * db ,
Version * version ) {
* value = cfd_ - > imm ( ) - > NumFlushed ( ) ;
return true ;
}
bool InternalStats : : HandleMemTableFlushPending ( uint64_t * value , DBImpl * db ,
Version * version ) {
// Return number of mem tables that are ready to flush (made immutable)
* value = ( cfd_ - > imm ( ) - > IsFlushPending ( ) ? 1 : 0 ) ;
return true ;
}
bool InternalStats : : HandleNumRunningFlushes ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = db - > num_running_flushes ( ) ;
return true ;
}
bool InternalStats : : HandleCompactionPending ( uint64_t * value , DBImpl * db ,
Version * version ) {
// 1 if the system already determines at least one compaction is needed.
// 0 otherwise,
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = ( cfd_ - > compaction_picker ( ) - > NeedsCompaction ( vstorage ) ? 1 : 0 ) ;
return true ;
}
switch ( property_type ) {
bool InternalStats : : HandleNumRunningCompactions ( uint64_t * value , DBImpl * db ,
case kNumImmutableMemTable :
Version * version ) {
* value = cfd_ - > imm ( ) - > NumNotFlushed ( ) ;
* value = db - > num_running_compactions_ ;
return true ;
return true ;
case kNumImmutableMemTableFlushed :
}
* value = cfd_ - > imm ( ) - > NumFlushed ( ) ;
return true ;
bool InternalStats : : HandleBackgroundErrors ( uint64_t * value , DBImpl * db ,
case kMemtableFlushPending :
Version * version ) {
// Return number of mem tables that are ready to flush (made immutable)
// Accumulated number of errors in background flushes or compactions.
* value = ( cfd_ - > imm ( ) - > IsFlushPending ( ) ? 1 : 0 ) ;
* value = GetBackgroundErrorCount ( ) ;
return true ;
return true ;
case kNumRunningFlushes :
}
* value = db - > num_running_flushes ( ) ;
return true ;
bool InternalStats : : HandleCurSizeActiveMemTable ( uint64_t * value , DBImpl * db ,
case kCompactionPending :
Version * version ) {
// 1 if the system already determines at least one compaction is needed.
// Current size of the active memtable
// 0 otherwise,
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) ;
* value = ( cfd_ - > compaction_picker ( ) - > NeedsCompaction ( vstorage ) ? 1 : 0 ) ;
return true ;
return true ;
}
case kNumRunningCompactions :
* value = db - > num_running_compactions_ ;
bool InternalStats : : HandleCurSizeAllMemTables ( uint64_t * value , DBImpl * db ,
return true ;
Version * version ) {
case kBackgroundErrors :
// Current size of the active memtable + immutable memtables
// Accumulated number of errors in background flushes or compactions.
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
* value = GetBackgroundErrorCount ( ) ;
cfd_ - > imm ( ) - > ApproximateUnflushedMemTablesMemoryUsage ( ) ;
return true ;
return true ;
case kCurSizeActiveMemTable :
}
// Current size of the active memtable
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) ;
bool InternalStats : : HandleSizeAllMemTables ( uint64_t * value , DBImpl * db ,
return true ;
Version * version ) {
case kCurSizeAllMemTables :
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
// Current size of the active memtable + immutable memtables
cfd_ - > imm ( ) - > ApproximateMemoryUsage ( ) ;
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
return true ;
cfd_ - > imm ( ) - > ApproximateUnflushedMemTablesMemoryUsage ( ) ;
}
return true ;
case kSizeAllMemTables :
bool InternalStats : : HandleNumEntriesActiveMemTable ( uint64_t * value , DBImpl * db ,
* value = cfd_ - > mem ( ) - > ApproximateMemoryUsage ( ) +
Version * version ) {
cfd_ - > imm ( ) - > ApproximateMemoryUsage ( ) ;
// Current number of entires in the active memtable
return true ;
* value = cfd_ - > mem ( ) - > num_entries ( ) ;
case kNumEntriesInMutableMemtable :
return true ;
// Current number of entires in the active memtable
}
* value = cfd_ - > mem ( ) - > num_entries ( ) ;
return true ;
bool InternalStats : : HandleNumEntriesImmMemTables ( uint64_t * value , DBImpl * db ,
case kNumEntriesInImmutableMemtable :
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 :
}
// Current number of entires in the active memtable
* value = cfd_ - > mem ( ) - > num_deletes ( ) ;
bool InternalStats : : HandleNumDeletesActiveMemTable ( uint64_t * value , DBImpl * db ,
return true ;
Version * version ) {
case kNumDeletesInImmutableMemtable :
// Current number of entires in the active memtable
// Current number of entries in the immutable memtables
* value = cfd_ - > mem ( ) - > num_deletes ( ) ;
* value = cfd_ - > imm ( ) - > current ( ) - > GetTotalNumDeletes ( ) ;
return true ;
return true ;
}
case kEstimatedNumKeys :
// Estimate number of entries in the column family:
bool InternalStats : : HandleNumDeletesImmMemTables ( uint64_t * value , DBImpl * db ,
// Use estimated entries in tables + total entries in memtables.
Version * version ) {
* value = cfd_ - > mem ( ) - > num_entries ( ) +
// Current number of entries in the immutable memtables
cfd_ - > imm ( ) - > current ( ) - > GetTotalNumEntries ( ) -
* value = cfd_ - > imm ( ) - > current ( ) - > GetTotalNumDeletes ( ) ;
( cfd_ - > mem ( ) - > num_deletes ( ) +
return true ;
cfd_ - > imm ( ) - > current ( ) - > GetTotalNumDeletes ( ) ) *
}
2 +
vstorage - > GetEstimatedActiveKeys ( ) ;
bool InternalStats : : HandleEstimateNumKeys ( uint64_t * value , DBImpl * db ,
return true ;
Version * version ) {
case kNumSnapshots :
// Estimate number of entries in the column family:
* value = db - > snapshots ( ) . count ( ) ;
// Use estimated entries in tables + total entries in memtables.
return true ;
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
case kOldestSnapshotTime :
* value = cfd_ - > mem ( ) - > num_entries ( ) +
* value = static_cast < uint64_t > ( db - > snapshots ( ) . GetOldestSnapshotTime ( ) ) ;
cfd_ - > imm ( ) - > current ( ) - > GetTotalNumEntries ( ) -
return true ;
( cfd_ - > mem ( ) - > num_deletes ( ) +
case kNumLiveVersions :
cfd_ - > imm ( ) - > current ( ) - > GetTotalNumDeletes ( ) ) *
* value = cfd_ - > GetNumLiveVersions ( ) ;
2 +
return true ;
vstorage - > GetEstimatedActiveKeys ( ) ;
case kIsFileDeletionEnabled :
return true ;
* value = db - > IsFileDeletionsEnabled ( ) ;
}
return true ;
case kBaseLevel :
bool InternalStats : : HandleNumSnapshots ( uint64_t * value , DBImpl * db ,
* value = vstorage - > base_level ( ) ;
Version * version ) {
return true ;
* value = db - > snapshots ( ) . count ( ) ;
case kTotalSstFilesSize :
return true ;
* value = cfd_ - > GetTotalSstFilesSize ( ) ;
}
return true ;
case kEstimatePendingCompactionBytes :
bool InternalStats : : HandleOldestSnapshotTime ( uint64_t * value , DBImpl * db ,
* value = vstorage - > estimated_compaction_needed_bytes ( ) ;
Version * version ) {
return true ;
* value = static_cast < uint64_t > ( db - > snapshots ( ) . GetOldestSnapshotTime ( ) ) ;
default :
return true ;
return false ;
}
}
bool InternalStats : : HandleNumLiveVersions ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = cfd_ - > GetNumLiveVersions ( ) ;
return true ;
}
bool InternalStats : : HandleIsFileDeletionsEnabled ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = db - > IsFileDeletionsEnabled ( ) ;
return true ;
}
bool InternalStats : : HandleBaseLevel ( uint64_t * value , DBImpl * db ,
Version * version ) {
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = vstorage - > base_level ( ) ;
return true ;
}
bool InternalStats : : HandleTotalSstFilesSize ( uint64_t * value , DBImpl * db ,
Version * version ) {
* value = cfd_ - > GetTotalSstFilesSize ( ) ;
return true ;
}
bool InternalStats : : HandleEstimatePendingCompactionBytes ( uint64_t * value ,
DBImpl * db ,
Version * version ) {
const auto * vstorage = cfd_ - > current ( ) - > storage_info ( ) ;
* value = vstorage - > estimated_compaction_needed_bytes ( ) ;
return true ;
}
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