@ -146,11 +146,17 @@ class BackupEngineImpl : public BackupEngine {
class BackupMeta {
class BackupMeta {
public :
public :
BackupMeta ( const std : : string & meta_filename ,
BackupMeta (
const std : : string & meta_filename , const std : : string & meta_tmp_filename ,
std : : unordered_map < std : : string , std : : shared_ptr < FileInfo > > * file_infos ,
std : : unordered_map < std : : string , std : : shared_ptr < FileInfo > > * file_infos ,
Env * env )
Env * env )
: timestamp_ ( 0 ) , sequence_number_ ( 0 ) , size_ ( 0 ) ,
: timestamp_ ( 0 ) ,
meta_filename_ ( meta_filename ) , file_infos_ ( file_infos ) , env_ ( env ) { }
sequence_number_ ( 0 ) ,
size_ ( 0 ) ,
meta_filename_ ( meta_filename ) ,
meta_tmp_filename_ ( meta_tmp_filename ) ,
file_infos_ ( file_infos ) ,
env_ ( env ) { }
BackupMeta ( const BackupMeta & ) = delete ;
BackupMeta ( const BackupMeta & ) = delete ;
BackupMeta & operator = ( const BackupMeta & ) = delete ;
BackupMeta & operator = ( const BackupMeta & ) = delete ;
@ -228,6 +234,7 @@ class BackupEngineImpl : public BackupEngine {
uint64_t size_ ;
uint64_t size_ ;
std : : string app_metadata_ ;
std : : string app_metadata_ ;
std : : string const meta_filename_ ;
std : : string const meta_filename_ ;
std : : string const meta_tmp_filename_ ;
// files with relative paths (without "/" prefix!!)
// files with relative paths (without "/" prefix!!)
std : : vector < std : : shared_ptr < FileInfo > > files_ ;
std : : vector < std : : shared_ptr < FileInfo > > files_ ;
std : : unordered_map < std : : string , std : : shared_ptr < FileInfo > > * file_infos_ ;
std : : unordered_map < std : : string , std : : shared_ptr < FileInfo > > * file_infos_ ;
@ -257,12 +264,14 @@ class BackupEngineImpl : public BackupEngine {
inline std : : string GetSharedFileRel ( const std : : string & file = " " ,
inline std : : string GetSharedFileRel ( const std : : string & file = " " ,
bool tmp = false ) const {
bool tmp = false ) const {
assert ( file . size ( ) = = 0 | | file [ 0 ] ! = ' / ' ) ;
assert ( file . size ( ) = = 0 | | file [ 0 ] ! = ' / ' ) ;
return " shared/ " + file + ( tmp ? " .tmp " : " " ) ;
return std : : string ( " shared/ " ) + ( tmp ? " . " : " " ) + file +
( tmp ? " .tmp " : " " ) ;
}
}
inline std : : string GetSharedFileWithChecksumRel ( const std : : string & file = " " ,
inline std : : string GetSharedFileWithChecksumRel ( const std : : string & file = " " ,
bool tmp = false ) const {
bool tmp = false ) const {
assert ( file . size ( ) = = 0 | | file [ 0 ] ! = ' / ' ) ;
assert ( file . size ( ) = = 0 | | file [ 0 ] ! = ' / ' ) ;
return GetSharedChecksumDirRel ( ) + " / " + file + ( tmp ? " .tmp " : " " ) ;
return GetSharedChecksumDirRel ( ) + " / " + ( tmp ? " . " : " " ) + file +
( tmp ? " .tmp " : " " ) ;
}
}
inline std : : string GetSharedFileWithChecksum ( const std : : string & file ,
inline std : : string GetSharedFileWithChecksum ( const std : : string & file ,
const uint32_t checksum_value ,
const uint32_t checksum_value ,
@ -283,8 +292,9 @@ class BackupEngineImpl : public BackupEngine {
inline std : : string GetBackupMetaDir ( ) const {
inline std : : string GetBackupMetaDir ( ) const {
return GetAbsolutePath ( " meta " ) ;
return GetAbsolutePath ( " meta " ) ;
}
}
inline std : : string GetBackupMetaFile ( BackupID backup_id ) const {
inline std : : string GetBackupMetaFile ( BackupID backup_id , bool tmp ) const {
return GetBackupMetaDir ( ) + " / " + rocksdb : : ToString ( backup_id ) ;
return GetBackupMetaDir ( ) + " / " + ( tmp ? " . " : " " ) +
rocksdb : : ToString ( backup_id ) + ( tmp ? " .tmp " : " " ) ;
}
}
// If size_limit == 0, there is no size limit, copy everything.
// If size_limit == 0, there is no size limit, copy everything.
@ -605,10 +615,11 @@ Status BackupEngineImpl::Initialize() {
continue ;
continue ;
}
}
assert ( backups_ . find ( backup_id ) = = backups_ . end ( ) ) ;
assert ( backups_ . find ( backup_id ) = = backups_ . end ( ) ) ;
backups_ . insert (
backups_ . insert ( std : : make_pair (
std : : make_pair ( backup_id , unique_ptr < BackupMeta > ( new BackupMeta (
backup_id , unique_ptr < BackupMeta > ( new BackupMeta (
GetBackupMetaFile ( backup_id ) ,
GetBackupMetaFile ( backup_id , false /* tmp */ ) ,
& backuped_file_infos_ , backup_env_ ) ) ) ) ;
GetBackupMetaFile ( backup_id , true /* tmp */ ) ,
& backuped_file_infos_ , backup_env_ ) ) ) ) ;
}
}
latest_backup_id_ = 0 ;
latest_backup_id_ = 0 ;
@ -736,10 +747,11 @@ Status BackupEngineImpl::CreateNewBackupWithMetadata(
BackupID new_backup_id = latest_backup_id_ + 1 ;
BackupID new_backup_id = latest_backup_id_ + 1 ;
assert ( backups_ . find ( new_backup_id ) = = backups_ . end ( ) ) ;
assert ( backups_ . find ( new_backup_id ) = = backups_ . end ( ) ) ;
auto ret = backups_ . insert (
auto ret = backups_ . insert ( std : : make_pair (
std : : make_pair ( new_backup_id , unique_ptr < BackupMeta > ( new BackupMeta (
new_backup_id , unique_ptr < BackupMeta > ( new BackupMeta (
GetBackupMetaFile ( new_backup_id ) ,
GetBackupMetaFile ( new_backup_id , false /* tmp */ ) ,
& backuped_file_infos_ , backup_env_ ) ) ) ) ;
GetBackupMetaFile ( new_backup_id , true /* tmp */ ) ,
& backuped_file_infos_ , backup_env_ ) ) ) ) ;
assert ( ret . second = = true ) ;
assert ( ret . second = = true ) ;
auto & new_backup = ret . first - > second ;
auto & new_backup = ret . first - > second ;
new_backup - > RecordTimestamp ( ) ;
new_backup - > RecordTimestamp ( ) ;
@ -1708,8 +1720,7 @@ Status BackupEngineImpl::BackupMeta::StoreToFile(bool sync) {
EnvOptions env_options ;
EnvOptions env_options ;
env_options . use_mmap_writes = false ;
env_options . use_mmap_writes = false ;
env_options . use_direct_writes = false ;
env_options . use_direct_writes = false ;
s = env_ - > NewWritableFile ( meta_filename_ + " .tmp " , & backup_meta_file ,
s = env_ - > NewWritableFile ( meta_tmp_filename_ , & backup_meta_file , env_options ) ;
env_options ) ;
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
return s ;
return s ;
}
}
@ -1751,7 +1762,7 @@ Status BackupEngineImpl::BackupMeta::StoreToFile(bool sync) {
s = backup_meta_file - > Close ( ) ;
s = backup_meta_file - > Close ( ) ;
}
}
if ( s . ok ( ) ) {
if ( s . ok ( ) ) {
s = env_ - > RenameFile ( meta_filename_ + " .tmp " , meta_filename_ ) ;
s = env_ - > RenameFile ( meta_tmp_ filename_ , meta_filename_ ) ;
}
}
return s ;
return s ;
}
}