@ -5,12 +5,60 @@
# pragma once
# pragma once
# ifndef ROCKSDB_LITE
# ifndef ROCKSDB_LITE
# include <atomic>
# include <memory>
# include <memory>
# include "rocksdb/table_properties.h"
# include "rocksdb/table_properties.h"
namespace rocksdb {
namespace rocksdb {
// A factory of a table property collector that marks a SST
// file as need-compaction when it observe at least "D" deletion
// entries in any "N" consecutive entires.
class CompactOnDeletionCollectorFactory
: public TablePropertiesCollectorFactory {
public :
virtual ~ CompactOnDeletionCollectorFactory ( ) { }
virtual TablePropertiesCollector * CreateTablePropertiesCollector (
TablePropertiesCollectorFactory : : Context context ) override ;
// Change the value of sliding_window_size "N"
// Setting it to 0 disables the delete triggered compaction
void SetWindowSize ( size_t sliding_window_size ) {
sliding_window_size_ . store ( sliding_window_size ) ;
}
// Change the value of deletion_trigger "D"
void SetDeletionTrigger ( size_t deletion_trigger ) {
deletion_trigger_ . store ( deletion_trigger ) ;
}
virtual const char * Name ( ) const override {
return " CompactOnDeletionCollector " ;
}
private :
friend std : : shared_ptr < CompactOnDeletionCollectorFactory >
NewCompactOnDeletionCollectorFactory (
size_t sliding_window_size ,
size_t deletion_trigger ) ;
// A factory of a table property collector that marks a SST
// file as need-compaction when it observe at least "D" deletion
// entries in any "N" consecutive entires.
//
// @param sliding_window_size "N"
// @param deletion_trigger "D"
CompactOnDeletionCollectorFactory (
size_t sliding_window_size ,
size_t deletion_trigger ) :
sliding_window_size_ ( sliding_window_size ) ,
deletion_trigger_ ( deletion_trigger ) { }
std : : atomic < size_t > sliding_window_size_ ;
std : : atomic < size_t > deletion_trigger_ ;
} ;
// Creates a factory of a table property collector that marks a SST
// Creates a factory of a table property collector that marks a SST
// file as need-compaction when it observe at least "D" deletion
// file as need-compaction when it observe at least "D" deletion
// entries in any "N" consecutive entires.
// entries in any "N" consecutive entires.
@ -20,7 +68,7 @@ namespace rocksdb {
// than the specified size.
// than the specified size.
// @param deletion_trigger "D". Note that even when "N" is changed,
// @param deletion_trigger "D". Note that even when "N" is changed,
// the specified number for "D" will not be changed.
// the specified number for "D" will not be changed.
extern std : : shared_ptr < TableProperties CollectorFactory>
extern std : : shared_ptr < CompactOnDeletion CollectorFactory>
NewCompactOnDeletionCollectorFactory (
NewCompactOnDeletionCollectorFactory (
size_t sliding_window_size ,
size_t sliding_window_size ,
size_t deletion_trigger ) ;
size_t deletion_trigger ) ;