@ -1728,7 +1728,8 @@ TEST_F(DBTest2, ReadAmpBitmapLiveInCacheAfterDBClose) {
// the blocks again regardless of them being already in the cache
// the blocks again regardless of them being already in the cache
return ;
return ;
}
}
uint32_t bytes_per_bit [ 2 ] = { 1 , 16 } ;
for ( size_t k = 0 ; k < 2 ; k + + ) {
std : : shared_ptr < Cache > lru_cache = NewLRUCache ( 1024 * 1024 * 1024 ) ;
std : : shared_ptr < Cache > lru_cache = NewLRUCache ( 1024 * 1024 * 1024 ) ;
std : : shared_ptr < Statistics > stats = rocksdb : : CreateDBStatistics ( ) ;
std : : shared_ptr < Statistics > stats = rocksdb : : CreateDBStatistics ( ) ;
@ -1738,7 +1739,7 @@ TEST_F(DBTest2, ReadAmpBitmapLiveInCacheAfterDBClose) {
bbto . use_delta_encoding = false ;
bbto . use_delta_encoding = false ;
// Huge block cache to make it easier to calculate read amplification
// Huge block cache to make it easier to calculate read amplification
bbto . block_cache = lru_cache ;
bbto . block_cache = lru_cache ;
bbto . read_amp_bytes_per_bit = 16 ;
bbto . read_amp_bytes_per_bit = bytes_per_bit [ k ] ;
options . table_factory . reset ( NewBlockBasedTableFactory ( bbto ) ) ;
options . table_factory . reset ( NewBlockBasedTableFactory ( bbto ) ) ;
options . statistics = stats ;
options . statistics = stats ;
DestroyAndReopen ( options ) ;
DestroyAndReopen ( options ) ;
@ -1760,12 +1761,13 @@ TEST_F(DBTest2, ReadAmpBitmapLiveInCacheAfterDBClose) {
// Iter1: Read half the DB, Read even keys
// Iter1: Read half the DB, Read even keys
// Key(0), Key(2), Key(4), Key(6), Key(8), ...
// Key(0), Key(2), Key(4), Key(6), Key(8), ...
for ( int i = 0 ; i < kNumEntries ; i + = 2 ) {
for ( int i = 0 ; i < kNumEntries ; i + = 2 ) {
std : : string k = Key ( i ) ;
std : : string key = Key ( i ) ;
ASSERT_OK ( db_ - > Get ( ReadOptions ( ) , k , & value ) ) ;
ASSERT_OK ( db_ - > Get ( ReadOptions ( ) , key , & value ) ) ;
if ( read_keys . find ( i ) = = read_keys . end ( ) ) {
if ( read_keys . find ( i ) = = read_keys . end ( ) ) {
auto ik = InternalKey ( k , 0 , ValueType : : kTypeValue ) ;
auto internal_key = InternalKey ( key , 0 , ValueType : : kTypeValue ) ;
total_useful_bytes + = GetEncodedEntrySize ( ik . size ( ) , value . size ( ) ) ;
total_useful_bytes + =
GetEncodedEntrySize ( internal_key . size ( ) , value . size ( ) ) ;
read_keys . insert ( i ) ;
read_keys . insert ( i ) ;
}
}
}
}
@ -1786,12 +1788,13 @@ TEST_F(DBTest2, ReadAmpBitmapLiveInCacheAfterDBClose) {
// Iter2: Read half the DB, Read odd keys
// Iter2: Read half the DB, Read odd keys
// Key(1), Key(3), Key(5), Key(7), Key(9), ...
// Key(1), Key(3), Key(5), Key(7), Key(9), ...
for ( int i = 1 ; i < kNumEntries ; i + = 2 ) {
for ( int i = 1 ; i < kNumEntries ; i + = 2 ) {
std : : string k = Key ( i ) ;
std : : string key = Key ( i ) ;
ASSERT_OK ( db_ - > Get ( ReadOptions ( ) , k , & value ) ) ;
ASSERT_OK ( db_ - > Get ( ReadOptions ( ) , key , & value ) ) ;
if ( read_keys . find ( i ) = = read_keys . end ( ) ) {
if ( read_keys . find ( i ) = = read_keys . end ( ) ) {
auto ik = InternalKey ( k , 0 , ValueType : : kTypeValue ) ;
auto internal_key = InternalKey ( key , 0 , ValueType : : kTypeValue ) ;
total_useful_bytes + = GetEncodedEntrySize ( ik . size ( ) , value . size ( ) ) ;
total_useful_bytes + =
GetEncodedEntrySize ( internal_key . size ( ) , value . size ( ) ) ;
read_keys . insert ( i ) ;
read_keys . insert ( i ) ;
}
}
}
}
@ -1801,9 +1804,17 @@ TEST_F(DBTest2, ReadAmpBitmapLiveInCacheAfterDBClose) {
size_t total_loaded_bytes_iter2 =
size_t total_loaded_bytes_iter2 =
options . statistics - > getTickerCount ( READ_AMP_TOTAL_READ_BYTES ) ;
options . statistics - > getTickerCount ( READ_AMP_TOTAL_READ_BYTES ) ;
// We reached read_amp of 100% because we read all the keys in the DB
// Read amp is on average 100% since we read all what we loaded in memory
if ( k = = 0 ) {
ASSERT_EQ ( total_useful_bytes_iter1 + total_useful_bytes_iter2 ,
ASSERT_EQ ( total_useful_bytes_iter1 + total_useful_bytes_iter2 ,
total_loaded_bytes_iter1 + total_loaded_bytes_iter2 ) ;
total_loaded_bytes_iter1 + total_loaded_bytes_iter2 ) ;
} else {
ASSERT_NEAR ( ( total_useful_bytes_iter1 + total_useful_bytes_iter2 ) * 1.0f /
( total_loaded_bytes_iter1 + total_loaded_bytes_iter2 ) ,
1 , .01 ) ;
}
}
}
}
# endif // !OS_SOLARIS
# endif // !OS_SOLARIS