@ -1462,12 +1462,6 @@ Status DBImpl::SwitchMemtable(ColumnFamilyData* cfd, WriteContext* context) {
context - > superversion_context . NewSuperVersion ( ) ;
context - > superversion_context . NewSuperVersion ( ) ;
}
}
# ifndef ROCKSDB_LITE
// PLEASE NOTE: We assume that there are no failable operations
// after lock is acquired below since we are already notifying
// client about mem table becoming immutable.
NotifyOnMemTableSealed ( cfd , memtable_info ) ;
# endif //ROCKSDB_LITE
}
}
ROCKS_LOG_INFO ( immutable_db_options_ . info_log ,
ROCKS_LOG_INFO ( immutable_db_options_ . info_log ,
" [%s] New memtable created with log file: #% " PRIu64
" [%s] New memtable created with log file: #% " PRIu64
@ -1476,10 +1470,7 @@ Status DBImpl::SwitchMemtable(ColumnFamilyData* cfd, WriteContext* context) {
mutex_ . Lock ( ) ;
mutex_ . Lock ( ) ;
if ( s . ok ( ) & & creating_new_log ) {
if ( s . ok ( ) & & creating_new_log ) {
log_write_mutex_ . Lock ( ) ;
log_write_mutex_ . Lock ( ) ;
logfile_number_ = new_log_number ;
assert ( new_log ! = nullptr ) ;
assert ( new_log ! = nullptr ) ;
log_empty_ = true ;
log_dir_synced_ = false ;
if ( ! logs_ . empty ( ) ) {
if ( ! logs_ . empty ( ) ) {
// Alway flush the buffer of the last log before switching to a new one
// Alway flush the buffer of the last log before switching to a new one
log : : Writer * cur_log_writer = logs_ . back ( ) . writer ;
log : : Writer * cur_log_writer = logs_ . back ( ) . writer ;
@ -1492,16 +1483,36 @@ Status DBImpl::SwitchMemtable(ColumnFamilyData* cfd, WriteContext* context) {
new_log_number ) ;
new_log_number ) ;
}
}
}
}
logs_ . emplace_back ( logfile_number_ , new_log ) ;
if ( s . ok ( ) ) {
alive_log_files_ . push_back ( LogFileNumberSize ( logfile_number_ ) ) ;
logfile_number_ = new_log_number ;
log_empty_ = true ;
log_dir_synced_ = false ;
logs_ . emplace_back ( logfile_number_ , new_log ) ;
alive_log_files_ . push_back ( LogFileNumberSize ( logfile_number_ ) ) ;
}
log_write_mutex_ . Unlock ( ) ;
log_write_mutex_ . Unlock ( ) ;
}
}
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
// how do we fail if we're not creating new log?
// how do we fail if we're not creating new log?
assert ( creating_new_log ) ;
assert ( creating_new_log ) ;
assert ( ! new_mem ) ;
if ( new_mem ) {
assert ( ! new_log ) ;
delete new_mem ;
}
if ( new_log ) {
delete new_log ;
}
SuperVersion * new_superversion =
context - > superversion_context . new_superversion . release ( ) ;
if ( new_superversion ! = nullptr ) {
delete new_superversion ;
}
// We may have lost data from the WritableFileBuffer in-memory buffer for
// the current log, so treat it as a fatal error and set bg_error
error_handler_ . SetBGError ( s , BackgroundErrorReason : : kMemTable ) ;
// Read back bg_error in order to get the right severity
s = error_handler_ . GetBGError ( ) ;
if ( two_write_queues_ ) {
if ( two_write_queues_ ) {
nonmem_write_thread_ . ExitUnbatched ( & nonmem_w ) ;
nonmem_write_thread_ . ExitUnbatched ( & nonmem_w ) ;
}
}
@ -1528,6 +1539,13 @@ Status DBImpl::SwitchMemtable(ColumnFamilyData* cfd, WriteContext* context) {
cfd - > SetMemtable ( new_mem ) ;
cfd - > SetMemtable ( new_mem ) ;
InstallSuperVersionAndScheduleWork ( cfd , & context - > superversion_context ,
InstallSuperVersionAndScheduleWork ( cfd , & context - > superversion_context ,
mutable_cf_options ) ;
mutable_cf_options ) ;
# ifndef ROCKSDB_LITE
mutex_ . Unlock ( ) ;
// Notify client that memtable is sealed, now that we have successfully
// installed a new memtable
NotifyOnMemTableSealed ( cfd , memtable_info ) ;
mutex_ . Lock ( ) ;
# endif // ROCKSDB_LITE
if ( two_write_queues_ ) {
if ( two_write_queues_ ) {
nonmem_write_thread_ . ExitUnbatched ( & nonmem_w ) ;
nonmem_write_thread_ . ExitUnbatched ( & nonmem_w ) ;
}
}