@ -2588,43 +2588,71 @@ void RepairCommand::DoCommand() {
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
const std : : string BackupCommand : : ARG_THREAD = " num_threads " ;
const std : : string BackupableCommand : : ARG_NUM_THREADS = " num_threads " ;
const std : : string BackupCommand : : ARG_BACKUP_ENV = " backup_env_uri " ;
const std : : string BackupableCommand : : ARG_BACKUP_ENV_URI = " backup_env_uri " ;
const std : : string BackupCommand : : ARG_BACKUP_DIR = " backup_dir " ;
const std : : string BackupableCommand : : ARG_BACKUP_DIR = " backup_dir " ;
const std : : string BackupableCommand : : ARG_STDERR_LOG_LEVEL = " stderr_log_level " ;
BackupCommand : : BackupCommand ( const std : : vector < std : : string > & params ,
BackupableCommand : : BackupableCommand (
const std : : vector < std : : string > & params ,
const std : : map < std : : string , std : : string > & options ,
const std : : map < std : : string , std : : string > & options ,
const std : : vector < std : : string > & flags )
const std : : vector < std : : string > & flags )
: LDBCommand (
: LDBCommand ( options , flags , false /* is_read_only */ ,
options , flags , false ,
BuildCmdLineOptions ( { ARG_BACKUP_ENV_URI , ARG_BACKUP_DIR ,
BuildCmdLineOptions ( { ARG_BACKUP_ENV , ARG_BACKUP_DIR , ARG_THREAD } ) ) ,
ARG_NUM_THREADS , ARG_STDERR_LOG_LEVEL } ) ) ,
thread_num _( 1 ) {
num_threads _( 1 ) {
auto itr = options . find ( ARG_THREAD ) ;
auto itr = options . find ( ARG_NUM_ THREADS ) ;
if ( itr ! = options . end ( ) ) {
if ( itr ! = options . end ( ) ) {
thread_num _ = std : : stoi ( itr - > second ) ;
num_threads _ = std : : stoi ( itr - > second ) ;
}
}
itr = options . find ( ARG_BACKUP_ENV ) ;
itr = options . find ( ARG_BACKUP_ENV_URI ) ;
if ( itr ! = options . end ( ) ) {
if ( itr ! = options . end ( ) ) {
test_cluster _ = itr - > second ;
backup_env_uri _ = itr - > second ;
}
}
itr = options . find ( ARG_BACKUP_DIR ) ;
itr = options . find ( ARG_BACKUP_DIR ) ;
if ( itr = = options . end ( ) ) {
if ( itr = = options . end ( ) ) {
exec_state_ = LDBCommandExecuteResult : : Failed ( " -- " + ARG_BACKUP_DIR +
exec_state_ = LDBCommandExecuteResult : : Failed ( " -- " + ARG_BACKUP_DIR +
" : missing backup directory " ) ;
" : missing backup directory " ) ;
} else {
} else {
test_path_ = itr - > second ;
backup_dir_ = itr - > second ;
}
itr = options . find ( ARG_STDERR_LOG_LEVEL ) ;
if ( itr ! = options . end ( ) ) {
int stderr_log_level = std : : stoi ( itr - > second ) ;
if ( stderr_log_level < 0 | |
stderr_log_level > = InfoLogLevel : : NUM_INFO_LOG_LEVELS ) {
exec_state_ = LDBCommandExecuteResult : : Failed (
ARG_STDERR_LOG_LEVEL + " must be >= 0 and < " +
std : : to_string ( InfoLogLevel : : NUM_INFO_LOG_LEVELS ) + " . " ) ;
} else {
logger_ . reset (
new StderrLogger ( static_cast < InfoLogLevel > ( stderr_log_level ) ) ) ;
}
}
}
}
}
void BackupCommand : : Help ( std : : string & ret ) {
void Backupable Command : : Help ( const std : : string & name , std : : string & ret ) {
ret . append ( " " ) ;
ret . append ( " " ) ;
ret . append ( BackupCommand : : Name ( ) ) ;
ret . append ( name ) ;
ret . append ( " [-- " + ARG_BACKUP_ENV + " ] " ) ;
ret . append ( " [-- " + ARG_BACKUP_ENV_URI + " ] " ) ;
ret . append ( " [-- " + ARG_BACKUP_DIR + " ] " ) ;
ret . append ( " [-- " + ARG_BACKUP_DIR + " ] " ) ;
ret . append ( " [-- " + ARG_THREAD + " ] " ) ;
ret . append ( " [-- " + ARG_NUM_THREADS + " ] " ) ;
ret . append ( " [-- " + ARG_STDERR_LOG_LEVEL + " =<int (InfoLogLevel)>] " ) ;
ret . append ( " \n " ) ;
ret . append ( " \n " ) ;
}
}
// ----------------------------------------------------------------------------
BackupCommand : : BackupCommand ( const std : : vector < std : : string > & params ,
const std : : map < std : : string , std : : string > & options ,
const std : : vector < std : : string > & flags )
: BackupableCommand ( params , options , flags ) { }
void BackupCommand : : Help ( std : : string & ret ) {
BackupableCommand : : Help ( Name ( ) , ret ) ;
}
void BackupCommand : : DoCommand ( ) {
void BackupCommand : : DoCommand ( ) {
BackupEngine * backup_engine ;
BackupEngine * backup_engine ;
Status status ;
Status status ;
@ -2634,10 +2662,11 @@ void BackupCommand::DoCommand() {
}
}
printf ( " open db OK \n " ) ;
printf ( " open db OK \n " ) ;
std : : unique_ptr < Env > custom_env_guard ;
std : : unique_ptr < Env > custom_env_guard ;
Env * custom_env = NewCustomObject < Env > ( test_cluster _, & custom_env_guard ) ;
Env * custom_env = NewCustomObject < Env > ( backup_env_uri _, & custom_env_guard ) ;
BackupableDBOptions backup_options =
BackupableDBOptions backup_options =
BackupableDBOptions ( test_path_ , custom_env ) ;
BackupableDBOptions ( backup_dir_ , custom_env ) ;
backup_options . max_background_operations = thread_num_ ;
backup_options . info_log = logger_ . get ( ) ;
backup_options . max_background_operations = num_threads_ ;
status = BackupEngine : : Open ( Env : : Default ( ) , backup_options , & backup_engine ) ;
status = BackupEngine : : Open ( Env : : Default ( ) , backup_options , & backup_engine ) ;
if ( status . ok ( ) ) {
if ( status . ok ( ) ) {
printf ( " open backup engine OK \n " ) ;
printf ( " open backup engine OK \n " ) ;
@ -2656,42 +2685,14 @@ void BackupCommand::DoCommand() {
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
const std : : string RestoreCommand : : ARG_BACKUP_ENV_URI = " backup_env_uri " ;
const std : : string RestoreCommand : : ARG_BACKUP_DIR = " backup_dir " ;
const std : : string RestoreCommand : : ARG_NUM_THREADS = " num_threads " ;
RestoreCommand : : RestoreCommand (
RestoreCommand : : RestoreCommand (
const std : : vector < std : : string > & params ,
const std : : vector < std : : string > & params ,
const std : : map < std : : string , std : : string > & options ,
const std : : map < std : : string , std : : string > & options ,
const std : : vector < std : : string > & flags )
const std : : vector < std : : string > & flags )
: LDBCommand ( options , flags , false /* is_read_only */ ,
: BackupableCommand ( params , options , flags ) { }
BuildCmdLineOptions (
{ ARG_BACKUP_ENV_URI , ARG_BACKUP_DIR , ARG_NUM_THREADS } ) ) ,
num_threads_ ( 1 ) {
auto itr = options . find ( ARG_NUM_THREADS ) ;
if ( itr ! = options . end ( ) ) {
num_threads_ = std : : stoi ( itr - > second ) ;
}
itr = options . find ( ARG_BACKUP_ENV_URI ) ;
if ( itr ! = options . end ( ) ) {
backup_env_uri_ = itr - > second ;
}
itr = options . find ( ARG_BACKUP_DIR ) ;
if ( itr = = options . end ( ) ) {
exec_state_ = LDBCommandExecuteResult : : Failed ( " -- " + ARG_BACKUP_DIR +
" : missing backup directory " ) ;
} else {
backup_dir_ = itr - > second ;
}
}
void RestoreCommand : : Help ( std : : string & ret ) {
void RestoreCommand : : Help ( std : : string & ret ) {
ret . append ( " " ) ;
BackupableCommand : : Help ( Name ( ) , ret ) ;
ret . append ( RestoreCommand : : Name ( ) ) ;
ret . append ( " [-- " + ARG_BACKUP_ENV_URI + " ] " ) ;
ret . append ( " [-- " + ARG_BACKUP_DIR + " ] " ) ;
ret . append ( " [-- " + ARG_NUM_THREADS + " ] " ) ;
ret . append ( " \n " ) ;
}
}
void RestoreCommand : : DoCommand ( ) {
void RestoreCommand : : DoCommand ( ) {
@ -2701,6 +2702,7 @@ void RestoreCommand::DoCommand() {
Status status ;
Status status ;
{
{
BackupableDBOptions opts ( backup_dir_ , custom_env ) ;
BackupableDBOptions opts ( backup_dir_ , custom_env ) ;
opts . info_log = logger_ . get ( ) ;
opts . max_background_operations = num_threads_ ;
opts . max_background_operations = num_threads_ ;
BackupEngineReadOnly * raw_restore_engine_ptr ;
BackupEngineReadOnly * raw_restore_engine_ptr ;
status = BackupEngineReadOnly : : Open ( Env : : Default ( ) , opts ,
status = BackupEngineReadOnly : : Open ( Env : : Default ( ) , opts ,