Support readahead during compaction for blob files (#9187)
	
		
	
				
					
				
			Summary: The patch adds a new BlobDB configuration option `blob_compaction_readahead_size` that can be used to enable prefetching data from blob files during compaction. This is important when using storage with higher latencies like HDDs or remote filesystems. If enabled, prefetching is used for all cases when blobs are read during compaction, namely garbage collection, compaction filters (when the existing value has to be read from a blob file), and `Merge` (when the value of the base `Put` is stored in a blob file). Pull Request resolved: https://github.com/facebook/rocksdb/pull/9187 Test Plan: Ran `make check` and the stress/crash test. Reviewed By: riversand963 Differential Revision: D32565512 Pulled By: ltamasi fbshipit-source-id: 87be9cebc3aa01cc227bec6b5f64d827b8164f5dmain
							parent
							
								
									cd4ea675e3
								
							
						
					
					
						commit
						dc5de45af8
					
				| @ -0,0 +1,21 @@ | ||||
| //  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).
 | ||||
| 
 | ||||
| #include "db/blob/prefetch_buffer_collection.h" | ||||
| 
 | ||||
| namespace ROCKSDB_NAMESPACE { | ||||
| 
 | ||||
| FilePrefetchBuffer* PrefetchBufferCollection::GetOrCreatePrefetchBuffer( | ||||
|     uint64_t file_number) { | ||||
|   auto& prefetch_buffer = prefetch_buffers_[file_number]; | ||||
|   if (!prefetch_buffer) { | ||||
|     prefetch_buffer.reset( | ||||
|         new FilePrefetchBuffer(readahead_size_, readahead_size_)); | ||||
|   } | ||||
| 
 | ||||
|   return prefetch_buffer.get(); | ||||
| } | ||||
| 
 | ||||
| }  // namespace ROCKSDB_NAMESPACE
 | ||||
| @ -0,0 +1,38 @@ | ||||
| //  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).
 | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include <cassert> | ||||
| #include <cstdint> | ||||
| #include <memory> | ||||
| #include <unordered_map> | ||||
| 
 | ||||
| #include "file/file_prefetch_buffer.h" | ||||
| #include "rocksdb/rocksdb_namespace.h" | ||||
| 
 | ||||
| namespace ROCKSDB_NAMESPACE { | ||||
| 
 | ||||
| // A class that owns a collection of FilePrefetchBuffers using the file number
 | ||||
| // as key. Used for implementing compaction readahead for blob files. Designed
 | ||||
| // to be accessed by a single thread only: every (sub)compaction needs its own
 | ||||
| // buffers since they are guaranteed to read different blobs from different
 | ||||
| // positions even when reading the same file.
 | ||||
| class PrefetchBufferCollection { | ||||
|  public: | ||||
|   explicit PrefetchBufferCollection(uint64_t readahead_size) | ||||
|       : readahead_size_(readahead_size) { | ||||
|     assert(readahead_size_ > 0); | ||||
|   } | ||||
| 
 | ||||
|   FilePrefetchBuffer* GetOrCreatePrefetchBuffer(uint64_t file_number); | ||||
| 
 | ||||
|  private: | ||||
|   uint64_t readahead_size_; | ||||
|   std::unordered_map<uint64_t, std::unique_ptr<FilePrefetchBuffer>> | ||||
|       prefetch_buffers_;  // maps file number to prefetch buffer
 | ||||
| }; | ||||
| 
 | ||||
| }  // namespace ROCKSDB_NAMESPACE
 | ||||
					Loading…
					
					
				
		Reference in new issue
	
	 Levi Tamasi
						Levi Tamasi