@ -319,7 +319,11 @@ Status DBImpl::WriteImpl(const WriteOptions& write_options,
PERF_TIMER_START ( write_pre_and_post_process_time ) ;
PERF_TIMER_START ( write_pre_and_post_process_time ) ;
}
}
log : : Writer * log_writer = logs_ . back ( ) . writer ;
log : : Writer * log_writer = logs_ . back ( ) . writer ;
LogFileNumberSize & log_file_number_size = alive_log_files_ . back ( ) ;
assert ( log_writer - > get_log_number ( ) = = log_file_number_size . number ) ;
mutex_ . Unlock ( ) ;
mutex_ . Unlock ( ) ;
@ -419,7 +423,8 @@ Status DBImpl::WriteImpl(const WriteOptions& write_options,
if ( status . ok ( ) & & ! write_options . disableWAL ) {
if ( status . ok ( ) & & ! write_options . disableWAL ) {
PERF_TIMER_GUARD ( write_wal_time ) ;
PERF_TIMER_GUARD ( write_wal_time ) ;
io_s = WriteToWAL ( write_group , log_writer , log_used , need_log_sync ,
io_s = WriteToWAL ( write_group , log_writer , log_used , need_log_sync ,
need_log_dir_sync , last_sequence + 1 ) ;
need_log_dir_sync , last_sequence + 1 ,
log_file_number_size ) ;
}
}
} else {
} else {
if ( status . ok ( ) & & ! write_options . disableWAL ) {
if ( status . ok ( ) & & ! write_options . disableWAL ) {
@ -586,6 +591,10 @@ Status DBImpl::PipelinedWriteImpl(const WriteOptions& write_options,
w . status = PreprocessWrite ( write_options , & need_log_sync , & write_context ) ;
w . status = PreprocessWrite ( write_options , & need_log_sync , & write_context ) ;
PERF_TIMER_START ( write_pre_and_post_process_time ) ;
PERF_TIMER_START ( write_pre_and_post_process_time ) ;
log : : Writer * log_writer = logs_ . back ( ) . writer ;
log : : Writer * log_writer = logs_ . back ( ) . writer ;
LogFileNumberSize & log_file_number_size = alive_log_files_ . back ( ) ;
assert ( log_writer - > get_log_number ( ) = = log_file_number_size . number ) ;
mutex_ . Unlock ( ) ;
mutex_ . Unlock ( ) ;
// This can set non-OK status if callback fail.
// This can set non-OK status if callback fail.
@ -649,8 +658,9 @@ Status DBImpl::PipelinedWriteImpl(const WriteOptions& write_options,
wal_write_group . size - 1 ) ;
wal_write_group . size - 1 ) ;
RecordTick ( stats_ , WRITE_DONE_BY_OTHER , wal_write_group . size - 1 ) ;
RecordTick ( stats_ , WRITE_DONE_BY_OTHER , wal_write_group . size - 1 ) ;
}
}
io_s = WriteToWAL ( wal_write_group , log_writer , log_used , need_log_sync ,
io_s =
need_log_dir_sync , current_sequence ) ;
WriteToWAL ( wal_write_group , log_writer , log_used , need_log_sync ,
need_log_dir_sync , current_sequence , log_file_number_size ) ;
w . status = io_s ;
w . status = io_s ;
}
}
@ -1178,17 +1188,9 @@ IOStatus DBImpl::WriteToWAL(const WriteBatch& merged_batch,
log : : Writer * log_writer , uint64_t * log_used ,
log : : Writer * log_writer , uint64_t * log_used ,
uint64_t * log_size ,
uint64_t * log_size ,
Env : : IOPriority rate_limiter_priority ,
Env : : IOPriority rate_limiter_priority ,
bool with_db_mutex , bool with_log_mutex ) {
LogFileNumberSize & log_file_number_size ) {
assert ( log_size ! = nullptr ) ;
assert ( log_size ! = nullptr ) ;
// Assert mutex explicitly.
if ( with_db_mutex ) {
mutex_ . AssertHeld ( ) ;
} else if ( two_write_queues_ ) {
log_write_mutex_ . AssertHeld ( ) ;
assert ( with_log_mutex ) ;
}
Slice log_entry = WriteBatchInternal : : Contents ( & merged_batch ) ;
Slice log_entry = WriteBatchInternal : : Contents ( & merged_batch ) ;
* log_size = log_entry . size ( ) ;
* log_size = log_entry . size ( ) ;
// When two_write_queues_ WriteToWAL has to be protected from concurretn calls
// When two_write_queues_ WriteToWAL has to be protected from concurretn calls
@ -1211,12 +1213,7 @@ IOStatus DBImpl::WriteToWAL(const WriteBatch& merged_batch,
* log_used = logfile_number_ ;
* log_used = logfile_number_ ;
}
}
total_log_size_ + = log_entry . size ( ) ;
total_log_size_ + = log_entry . size ( ) ;
if ( with_db_mutex | | with_log_mutex ) {
log_file_number_size . AddSize ( * log_size ) ;
assert ( alive_log_files_tail_ = = alive_log_files_ . rbegin ( ) ) ;
assert ( alive_log_files_tail_ ! = alive_log_files_ . rend ( ) ) ;
}
LogFileNumberSize & last_alive_log = * alive_log_files_tail_ ;
last_alive_log . AddSize ( * log_size ) ;
log_empty_ = false ;
log_empty_ = false ;
return io_s ;
return io_s ;
}
}
@ -1224,7 +1221,8 @@ IOStatus DBImpl::WriteToWAL(const WriteBatch& merged_batch,
IOStatus DBImpl : : WriteToWAL ( const WriteThread : : WriteGroup & write_group ,
IOStatus DBImpl : : WriteToWAL ( const WriteThread : : WriteGroup & write_group ,
log : : Writer * log_writer , uint64_t * log_used ,
log : : Writer * log_writer , uint64_t * log_used ,
bool need_log_sync , bool need_log_dir_sync ,
bool need_log_sync , bool need_log_dir_sync ,
SequenceNumber sequence ) {
SequenceNumber sequence ,
LogFileNumberSize & log_file_number_size ) {
IOStatus io_s ;
IOStatus io_s ;
assert ( ! two_write_queues_ ) ;
assert ( ! two_write_queues_ ) ;
assert ( ! write_group . leader - > disable_wal ) ;
assert ( ! write_group . leader - > disable_wal ) ;
@ -1245,7 +1243,8 @@ IOStatus DBImpl::WriteToWAL(const WriteThread::WriteGroup& write_group,
uint64_t log_size ;
uint64_t log_size ;
io_s = WriteToWAL ( * merged_batch , log_writer , log_used , & log_size ,
io_s = WriteToWAL ( * merged_batch , log_writer , log_used , & log_size ,
write_group . leader - > rate_limiter_priority ) ;
write_group . leader - > rate_limiter_priority ,
log_file_number_size ) ;
if ( to_be_cached_state ) {
if ( to_be_cached_state ) {
cached_recoverable_state_ = * to_be_cached_state ;
cached_recoverable_state_ = * to_be_cached_state ;
cached_recoverable_state_empty_ = false ;
cached_recoverable_state_empty_ = false ;
@ -1339,10 +1338,14 @@ IOStatus DBImpl::ConcurrentWriteToWAL(
WriteBatchInternal : : SetSequence ( merged_batch , sequence ) ;
WriteBatchInternal : : SetSequence ( merged_batch , sequence ) ;
log : : Writer * log_writer = logs_ . back ( ) . writer ;
log : : Writer * log_writer = logs_ . back ( ) . writer ;
LogFileNumberSize & log_file_number_size = alive_log_files_ . back ( ) ;
assert ( log_writer - > get_log_number ( ) = = log_file_number_size . number ) ;
uint64_t log_size ;
uint64_t log_size ;
io_s = WriteToWAL ( * merged_batch , log_writer , log_used , & log_size ,
io_s = WriteToWAL ( * merged_batch , log_writer , log_used , & log_size ,
write_group . leader - > rate_limiter_priority ,
write_group . leader - > rate_limiter_priority ,
/*with_db_mutex=*/ false , /*with_log_mutex=*/ true ) ;
log_file_number_siz e) ;
if ( to_be_cached_state ) {
if ( to_be_cached_state ) {
cached_recoverable_state_ = * to_be_cached_state ;
cached_recoverable_state_ = * to_be_cached_state ;
cached_recoverable_state_empty_ = false ;
cached_recoverable_state_empty_ = false ;
@ -1998,7 +2001,6 @@ Status DBImpl::SwitchMemtable(ColumnFamilyData* cfd, WriteContext* context) {
log_dir_synced_ = false ;
log_dir_synced_ = false ;
logs_ . emplace_back ( logfile_number_ , new_log ) ;
logs_ . emplace_back ( logfile_number_ , new_log ) ;
alive_log_files_ . push_back ( LogFileNumberSize ( logfile_number_ ) ) ;
alive_log_files_ . push_back ( LogFileNumberSize ( logfile_number_ ) ) ;
alive_log_files_tail_ = alive_log_files_ . rbegin ( ) ;
}
}
log_write_mutex_ . Unlock ( ) ;
log_write_mutex_ . Unlock ( ) ;
}
}