fork of https://github.com/oxigraph/rocksdb and https://github.com/facebook/rocksdb for nextgraph and oxigraph
				
			
			
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							89 lines
						
					
					
						
							2.8 KiB
						
					
					
				
			
		
		
	
	
							89 lines
						
					
					
						
							2.8 KiB
						
					
					
				| //  Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
 | |
| //  This source code is licensed under the BSD-style license found in the
 | |
| //  LICENSE file in the root directory of this source tree. An additional grant
 | |
| //  of patent rights can be found in the PATENTS file in the same directory.
 | |
| 
 | |
| #pragma once
 | |
| #ifndef ROCKSDB_LITE
 | |
| 
 | |
| #include <map>
 | |
| #include <string>
 | |
| #include <vector>
 | |
| 
 | |
| #include "rocksdb/db.h"
 | |
| #include "rocksdb/utilities/date_tiered_db.h"
 | |
| #include "util/cf_options.h"
 | |
| #include "util/instrumented_mutex.h"
 | |
| 
 | |
| namespace rocksdb {
 | |
| 
 | |
| // Implementation of DateTieredDB.
 | |
| class DateTieredDBImpl : public DateTieredDB {
 | |
|  public:
 | |
|   DateTieredDBImpl(DB* db, Options options,
 | |
|                    const std::vector<ColumnFamilyDescriptor>& descriptors,
 | |
|                    const std::vector<ColumnFamilyHandle*>& handles, int64_t ttl,
 | |
|                    int64_t column_family_interval);
 | |
| 
 | |
|   virtual ~DateTieredDBImpl();
 | |
| 
 | |
|   Status Put(const WriteOptions& options, const Slice& key,
 | |
|              const Slice& val) override;
 | |
| 
 | |
|   Status Get(const ReadOptions& options, const Slice& key,
 | |
|              std::string* value) override;
 | |
| 
 | |
|   Status Delete(const WriteOptions& options, const Slice& key) override;
 | |
| 
 | |
|   bool KeyMayExist(const ReadOptions& options, const Slice& key,
 | |
|                    std::string* value, bool* value_found = nullptr) override;
 | |
| 
 | |
|   Status Merge(const WriteOptions& options, const Slice& key,
 | |
|                const Slice& value) override;
 | |
| 
 | |
|   Iterator* NewIterator(const ReadOptions& opts) override;
 | |
| 
 | |
|   Status DropObsoleteColumnFamilies() override;
 | |
| 
 | |
|   // Extract timestamp from key.
 | |
|   static Status GetTimestamp(const Slice& key, int64_t* result);
 | |
| 
 | |
|  private:
 | |
|   // Base database object
 | |
|   DB* db_;
 | |
| 
 | |
|   const ColumnFamilyOptions cf_options_;
 | |
| 
 | |
|   const ImmutableCFOptions ioptions_;
 | |
| 
 | |
|   // Storing all column family handles for time series data.
 | |
|   std::vector<ColumnFamilyHandle*> handles_;
 | |
| 
 | |
|   // Manages a mapping from a column family's maximum timestamp to its handle.
 | |
|   std::map<int64_t, ColumnFamilyHandle*> handle_map_;
 | |
| 
 | |
|   // A time-to-live value to indicate when the data should be removed.
 | |
|   int64_t ttl_;
 | |
| 
 | |
|   // An variable to indicate the time range of a column family.
 | |
|   int64_t column_family_interval_;
 | |
| 
 | |
|   // Indicate largest maximum timestamp of a column family.
 | |
|   int64_t latest_timebound_;
 | |
| 
 | |
|   // Mutex to protect handle_map_ operations.
 | |
|   InstrumentedMutex mutex_;
 | |
| 
 | |
|   // Internal method to execute Put and Merge in batch.
 | |
|   Status Write(const WriteOptions& opts, WriteBatch* updates);
 | |
| 
 | |
|   Status CreateColumnFamily(ColumnFamilyHandle** column_family);
 | |
| 
 | |
|   Status FindColumnFamily(int64_t keytime, ColumnFamilyHandle** column_family,
 | |
|                           bool create_if_missing);
 | |
| 
 | |
|   static bool IsStale(int64_t keytime, int64_t ttl, Env* env);
 | |
| };
 | |
| 
 | |
| }  // namespace rocksdb
 | |
| #endif  // ROCKSDB_LITE
 | |
| 
 |