Minor improvement to #8428 (Account for dictionary-building buffer in global memory limit) (#9032)

Summary:
Summary/Context:
- Renamed `cache_rev_mng` to `compression_dict_buffer_cache_res_mgr`
   - It is to distinguish with other potential `cache_res_mgr` in `BlockBasedTableBuilder` and to use correct short-hand for the words "reservation", "manager"
- Added `table_options.block_cache == nullptr` in additional to `table_options.no_block_cache == true` to be conditions where we don't create a `CacheReservationManager`
   - Theoretically `table_options.no_block_cache == true` is equivalent to `table_options.block_cache == nullptr` by API. But since segment fault will be generated by passing `nullptr` into `CacheReservationManager`'s constructor, it does not hurt to directly verify  `table_options.block_cache != nullptr` before passing in
- Renamed `is_cache_full` to `exceeds_global_block_cache_limit`
   - It is to hide implementation detail of cache reservation and to emphasize on the concept/design intent of caping memory within global block cache limit

Pull Request resolved: https://github.com/facebook/rocksdb/pull/9032

Test Plan: - Passing existing tests

Reviewed By: ajkr

Differential Revision: D32005807

Pulled By: hx235

fbshipit-source-id: 619fd17bb924199de3db5924d8ab7dae53b1efa2
main
hx235 3 years ago committed by Facebook GitHub Bot
parent 230c98f3ce
commit a5ec5e3ea0
  1. 29
      table/block_based/block_based_table_builder.cc

@ -316,7 +316,8 @@ struct BlockBasedTableBuilder::Rep {
// `kBuffered` state is allowed only as long as the buffering of uncompressed // `kBuffered` state is allowed only as long as the buffering of uncompressed
// data blocks (see `data_block_buffers`) does not exceed `buffer_limit`. // data blocks (see `data_block_buffers`) does not exceed `buffer_limit`.
uint64_t buffer_limit; uint64_t buffer_limit;
std::unique_ptr<CacheReservationManager> cache_rev_mng; std::unique_ptr<CacheReservationManager>
compression_dict_buffer_cache_res_mgr;
const bool use_delta_encoding_for_index_values; const bool use_delta_encoding_for_index_values;
std::unique_ptr<FilterBlockBuilder> filter_builder; std::unique_ptr<FilterBlockBuilder> filter_builder;
char cache_key_prefix[BlockBasedTable::kMaxCacheKeyPrefixSize]; char cache_key_prefix[BlockBasedTable::kMaxCacheKeyPrefixSize];
@ -450,10 +451,10 @@ struct BlockBasedTableBuilder::Rep {
buffer_limit = std::min(tbo.target_file_size, buffer_limit = std::min(tbo.target_file_size,
compression_opts.max_dict_buffer_bytes); compression_opts.max_dict_buffer_bytes);
} }
if (table_options.no_block_cache) { if (table_options.no_block_cache || table_options.block_cache == nullptr) {
cache_rev_mng.reset(nullptr); compression_dict_buffer_cache_res_mgr.reset(nullptr);
} else { } else {
cache_rev_mng.reset( compression_dict_buffer_cache_res_mgr.reset(
new CacheReservationManager(table_options.block_cache)); new CacheReservationManager(table_options.block_cache));
} }
for (uint32_t i = 0; i < compression_opts.parallel_threads; i++) { for (uint32_t i = 0; i < compression_opts.parallel_threads; i++) {
@ -912,19 +913,21 @@ void BlockBasedTableBuilder::Add(const Slice& key, const Slice& value) {
if (r->state == Rep::State::kBuffered) { if (r->state == Rep::State::kBuffered) {
bool exceeds_buffer_limit = bool exceeds_buffer_limit =
(r->buffer_limit != 0 && r->data_begin_offset > r->buffer_limit); (r->buffer_limit != 0 && r->data_begin_offset > r->buffer_limit);
bool is_cache_full = false; bool exceeds_global_block_cache_limit = false;
// Increase cache reservation for the last buffered data block // Increase cache reservation for the last buffered data block
// only if the block is not going to be unbuffered immediately // only if the block is not going to be unbuffered immediately
// and there exists a cache reservation manager // and there exists a cache reservation manager
if (!exceeds_buffer_limit && r->cache_rev_mng != nullptr) { if (!exceeds_buffer_limit &&
Status s = r->cache_rev_mng->UpdateCacheReservation< r->compression_dict_buffer_cache_res_mgr != nullptr) {
CacheEntryRole::kCompressionDictionaryBuildingBuffer>( Status s =
r->data_begin_offset); r->compression_dict_buffer_cache_res_mgr->UpdateCacheReservation<
is_cache_full = s.IsIncomplete(); CacheEntryRole::kCompressionDictionaryBuildingBuffer>(
r->data_begin_offset);
exceeds_global_block_cache_limit = s.IsIncomplete();
} }
if (exceeds_buffer_limit || is_cache_full) { if (exceeds_buffer_limit || exceeds_global_block_cache_limit) {
EnterUnbuffered(); EnterUnbuffered();
} }
} }
@ -1971,8 +1974,8 @@ void BlockBasedTableBuilder::EnterUnbuffered() {
} }
r->data_block_buffers.clear(); r->data_block_buffers.clear();
r->data_begin_offset = 0; r->data_begin_offset = 0;
if (r->cache_rev_mng != nullptr) { if (r->compression_dict_buffer_cache_res_mgr != nullptr) {
Status s = r->cache_rev_mng->UpdateCacheReservation< Status s = r->compression_dict_buffer_cache_res_mgr->UpdateCacheReservation<
CacheEntryRole::kCompressionDictionaryBuildingBuffer>( CacheEntryRole::kCompressionDictionaryBuildingBuffer>(
r->data_begin_offset); r->data_begin_offset);
s.PermitUncheckedError(); s.PermitUncheckedError();

Loading…
Cancel
Save