@ -28,11 +28,12 @@ const size_t kFadviseTrigger = 1024 * 1024; // 1MB
struct SstFileWriter : : Rep {
struct SstFileWriter : : Rep {
Rep ( const EnvOptions & _env_options , const Options & options ,
Rep ( const EnvOptions & _env_options , const Options & options ,
const Comparator * _user_comparator , ColumnFamilyHandle * _cfh ,
Env : : IOPriority _io_priority , const Comparator * _user_comparator ,
bool _invalidate_page_cache )
ColumnFamilyHandle * _cfh , bool _invalidate_page_cache )
: env_options ( _env_options ) ,
: env_options ( _env_options ) ,
ioptions ( options ) ,
ioptions ( options ) ,
mutable_cf_options ( options ) ,
mutable_cf_options ( options ) ,
io_priority ( _io_priority ) ,
internal_comparator ( _user_comparator ) ,
internal_comparator ( _user_comparator ) ,
cfh ( _cfh ) ,
cfh ( _cfh ) ,
invalidate_page_cache ( _invalidate_page_cache ) ,
invalidate_page_cache ( _invalidate_page_cache ) ,
@ -43,15 +44,16 @@ struct SstFileWriter::Rep {
EnvOptions env_options ;
EnvOptions env_options ;
ImmutableCFOptions ioptions ;
ImmutableCFOptions ioptions ;
MutableCFOptions mutable_cf_options ;
MutableCFOptions mutable_cf_options ;
Env : : IOPriority io_priority ;
InternalKeyComparator internal_comparator ;
InternalKeyComparator internal_comparator ;
ExternalSstFileInfo file_info ;
ExternalSstFileInfo file_info ;
InternalKey ikey ;
InternalKey ikey ;
std : : string column_family_name ;
std : : string column_family_name ;
ColumnFamilyHandle * cfh ;
ColumnFamilyHandle * cfh ;
// If true, We will give the OS a hint that this file pages is not needed
// If true, We will give the OS a hint that this file pages is not needed
// everytime we write 1MB to the file
// everytime we write 1MB to the file.
bool invalidate_page_cache ;
bool invalidate_page_cache ;
// t he size of the file during the last time we called Fadvise to remove
// T he size of the file during the last time we called Fadvise to remove
// cached pages from page cache.
// cached pages from page cache.
uint64_t last_fadvise_size ;
uint64_t last_fadvise_size ;
} ;
} ;
@ -60,9 +62,10 @@ SstFileWriter::SstFileWriter(const EnvOptions& env_options,
const Options & options ,
const Options & options ,
const Comparator * user_comparator ,
const Comparator * user_comparator ,
ColumnFamilyHandle * column_family ,
ColumnFamilyHandle * column_family ,
bool invalidate_page_cache )
bool invalidate_page_cache ,
: rep_ ( new Rep ( env_options , options , user_comparator , column_family ,
Env : : IOPriority io_priority )
invalidate_page_cache ) ) {
: rep_ ( new Rep ( env_options , options , io_priority , user_comparator ,
column_family , invalidate_page_cache ) ) {
rep_ - > file_info . file_size = 0 ;
rep_ - > file_info . file_size = 0 ;
}
}
@ -72,12 +75,10 @@ SstFileWriter::~SstFileWriter() {
// abandon the builder.
// abandon the builder.
rep_ - > builder - > Abandon ( ) ;
rep_ - > builder - > Abandon ( ) ;
}
}
delete rep_ ;
}
}
Status SstFileWriter : : Open ( const std : : string & file_path ) {
Status SstFileWriter : : Open ( const std : : string & file_path ) {
Rep * r = rep_ ;
Rep * r = rep_ . get ( ) ;
Status s ;
Status s ;
std : : unique_ptr < WritableFile > sst_file ;
std : : unique_ptr < WritableFile > sst_file ;
s = r - > ioptions . env - > NewWritableFile ( file_path , & sst_file , r - > env_options ) ;
s = r - > ioptions . env - > NewWritableFile ( file_path , & sst_file , r - > env_options ) ;
@ -85,6 +86,8 @@ Status SstFileWriter::Open(const std::string& file_path) {
return s ;
return s ;
}
}
sst_file - > SetIOPriority ( r - > io_priority ) ;
CompressionType compression_type ;
CompressionType compression_type ;
if ( r - > ioptions . bottommost_compression ! = kDisableCompressionOption ) {
if ( r - > ioptions . bottommost_compression ! = kDisableCompressionOption ) {
compression_type = r - > ioptions . bottommost_compression ;
compression_type = r - > ioptions . bottommost_compression ;
@ -146,7 +149,7 @@ Status SstFileWriter::Open(const std::string& file_path) {
}
}
Status SstFileWriter : : Add ( const Slice & user_key , const Slice & value ) {
Status SstFileWriter : : Add ( const Slice & user_key , const Slice & value ) {
Rep * r = rep_ ;
Rep * r = rep_ . get ( ) ;
if ( ! r - > builder ) {
if ( ! r - > builder ) {
return Status : : InvalidArgument ( " File is not opened " ) ;
return Status : : InvalidArgument ( " File is not opened " ) ;
}
}
@ -166,7 +169,7 @@ Status SstFileWriter::Add(const Slice& user_key, const Slice& value) {
ValueType : : kTypeValue /* Put */ ) ;
ValueType : : kTypeValue /* Put */ ) ;
r - > builder - > Add ( r - > ikey . Encode ( ) , value ) ;
r - > builder - > Add ( r - > ikey . Encode ( ) , value ) ;
// u pdate file info
// U pdate file info
r - > file_info . num_entries + + ;
r - > file_info . num_entries + + ;
r - > file_info . largest_key . assign ( user_key . data ( ) , user_key . size ( ) ) ;
r - > file_info . largest_key . assign ( user_key . data ( ) , user_key . size ( ) ) ;
r - > file_info . file_size = r - > builder - > FileSize ( ) ;
r - > file_info . file_size = r - > builder - > FileSize ( ) ;
@ -177,7 +180,7 @@ Status SstFileWriter::Add(const Slice& user_key, const Slice& value) {
}
}
Status SstFileWriter : : Finish ( ExternalSstFileInfo * file_info ) {
Status SstFileWriter : : Finish ( ExternalSstFileInfo * file_info ) {
Rep * r = rep_ ;
Rep * r = rep_ . get ( ) ;
if ( ! r - > builder ) {
if ( ! r - > builder ) {
return Status : : InvalidArgument ( " File is not opened " ) ;
return Status : : InvalidArgument ( " File is not opened " ) ;
}
}
@ -208,7 +211,7 @@ Status SstFileWriter::Finish(ExternalSstFileInfo* file_info) {
}
}
void SstFileWriter : : InvalidatePageCache ( bool closing ) {
void SstFileWriter : : InvalidatePageCache ( bool closing ) {
Rep * r = rep_ ;
Rep * r = rep_ . get ( ) ;
if ( r - > invalidate_page_cache = = false ) {
if ( r - > invalidate_page_cache = = false ) {
// Fadvise disabled
// Fadvise disabled
return ;
return ;