From 97dabc8b0b3ec69d04bc744c19a7beaecc8b108b Mon Sep 17 00:00:00 2001 From: yukang Date: Thu, 8 Feb 2024 11:44:36 +0800 Subject: [PATCH 1/3] add migrate notes for background migrations --- ckb-bin/src/subcommand/migrate.rs | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/ckb-bin/src/subcommand/migrate.rs b/ckb-bin/src/subcommand/migrate.rs index 1bc0db2f43..5a41692b73 100644 --- a/ckb-bin/src/subcommand/migrate.rs +++ b/ckb-bin/src/subcommand/migrate.rs @@ -37,6 +37,13 @@ pub fn migrate(args: MigrateArgs) -> Result<(), ExitCode> { return Ok(()); } + if migrate.can_run_in_background(&db) && !args.force { + eprintln!("The pending migrations are all background migrations.\n\ + You can skip migration and start CKB directly, the migration will be done in the background.\n\ + If you want to migrate the data manually, please use --force to migrate without interactive prompt."); + return Ok(()); + } + if migrate.require_expensive(&db) && !args.force { if std::io::stdin().is_terminal() && std::io::stdout().is_terminal() { let input = prompt("\ From 4d769255aa1c4b35d042bf2c6085b918896c8c86 Mon Sep 17 00:00:00 2001 From: yukang Date: Thu, 8 Feb 2024 12:39:16 +0800 Subject: [PATCH 2/3] migrate subcommand will ignore background migrations by default --- ckb-bin/src/subcommand/migrate.rs | 11 ++--------- db-migration/src/lib.rs | 15 +++++++++++---- shared/src/shared_builder.rs | 5 ++--- util/app-config/src/args.rs | 2 ++ util/app-config/src/cli.rs | 8 ++++++++ util/app-config/src/lib.rs | 2 ++ util/migrate/src/migrate.rs | 8 ++++---- util/migrate/src/tests.rs | 2 +- 8 files changed, 32 insertions(+), 21 deletions(-) diff --git a/ckb-bin/src/subcommand/migrate.rs b/ckb-bin/src/subcommand/migrate.rs index 5a41692b73..e20aeea068 100644 --- a/ckb-bin/src/subcommand/migrate.rs +++ b/ckb-bin/src/subcommand/migrate.rs @@ -15,7 +15,7 @@ pub fn migrate(args: MigrateArgs) -> Result<(), ExitCode> { })?; if let Some(db) = read_only_db { - let db_status = migrate.check(&db); + let db_status = migrate.check(&db, args.include_background); if matches!(db_status, Ordering::Greater) { eprintln!( "The database was created by a higher version CKB executable binary \n\ @@ -37,14 +37,7 @@ pub fn migrate(args: MigrateArgs) -> Result<(), ExitCode> { return Ok(()); } - if migrate.can_run_in_background(&db) && !args.force { - eprintln!("The pending migrations are all background migrations.\n\ - You can skip migration and start CKB directly, the migration will be done in the background.\n\ - If you want to migrate the data manually, please use --force to migrate without interactive prompt."); - return Ok(()); - } - - if migrate.require_expensive(&db) && !args.force { + if migrate.require_expensive(&db, args.include_background) && !args.force { if std::io::stdin().is_terminal() && std::io::stdout().is_terminal() { let input = prompt("\ \n\ diff --git a/db-migration/src/lib.rs b/db-migration/src/lib.rs index 038bbf1d00..3258192542 100644 --- a/db-migration/src/lib.rs +++ b/db-migration/src/lib.rs @@ -115,7 +115,7 @@ impl Migrations { /// - Equal: The database version is matched with the executable binary version. /// - Greater: The database version is greater than the matched version of the executable binary. /// Requires upgrade the executable binary. - pub fn check(&self, db: &ReadOnlyDB) -> Ordering { + pub fn check(&self, db: &ReadOnlyDB, include_background: bool) -> Ordering { let db_version = match db .get_pinned_default(MIGRATION_VERSION_KEY) .expect("get the version of database") @@ -135,9 +135,12 @@ impl Migrations { }; debug!("Current database version [{}]", db_version); - let latest_version = self + let migrations = self .migrations .values() + .filter(|m| include_background || !m.run_in_background()); + + let latest_version = migrations .last() .unwrap_or_else(|| panic!("should have at least one version")) .version(); @@ -147,7 +150,7 @@ impl Migrations { } /// Check if the migrations will consume a lot of time. - pub fn expensive(&self, db: &ReadOnlyDB) -> bool { + pub fn expensive(&self, db: &ReadOnlyDB, include_background: bool) -> bool { let db_version = match db .get_pinned_default(MIGRATION_VERSION_KEY) .expect("get the version of database") @@ -162,8 +165,12 @@ impl Migrations { } }; - self.migrations + let migrations = self + .migrations .values() + .filter(|m| include_background || !m.run_in_background()); + + migrations .skip_while(|m| m.version() <= db_version.as_str()) .any(|m| m.expensive()) } diff --git a/shared/src/shared_builder.rs b/shared/src/shared_builder.rs index 6a0ef7cd38..5f2a7b7098 100644 --- a/shared/src/shared_builder.rs +++ b/shared/src/shared_builder.rs @@ -62,7 +62,7 @@ pub fn open_or_create_db( })?; if let Some(db) = read_only_db { - match migrate.check(&db) { + match migrate.check(&db, true) { Ordering::Greater => { eprintln!( "The database was created by a higher version CKB executable binary \n\ @@ -74,8 +74,7 @@ pub fn open_or_create_db( Ordering::Equal => Ok(RocksDB::open(config, COLUMNS)), Ordering::Less => { let can_run_in_background = migrate.can_run_in_background(&db); - eprintln!("can_run_in_background: {}", can_run_in_background); - if migrate.require_expensive(&db) && !can_run_in_background { + if migrate.require_expensive(&db, false) && !can_run_in_background { eprintln!( "For optimal performance, CKB recommends migrating your data into a new format.\n\ If you prefer to stick with the older version, \n\ diff --git a/util/app-config/src/args.rs b/util/app-config/src/args.rs index 872517720a..e31abea037 100644 --- a/util/app-config/src/args.rs +++ b/util/app-config/src/args.rs @@ -202,6 +202,8 @@ pub struct MigrateArgs { pub check: bool, /// Do migration without interactive prompt. pub force: bool, + /// Whether include background migrations + pub include_background: bool, } impl CustomizeSpec { diff --git a/util/app-config/src/cli.rs b/util/app-config/src/cli.rs index 9e28071a42..16cc95fd6e 100644 --- a/util/app-config/src/cli.rs +++ b/util/app-config/src/cli.rs @@ -60,6 +60,8 @@ pub const ARG_P2P_PORT: &str = "p2p-port"; pub const ARG_RPC_PORT: &str = "rpc-port"; /// Command line argument `--force`. pub const ARG_FORCE: &str = "force"; +/// Command line argument `--include-background`. +pub const ARG_INCLUDE_BACKGROUND: &str = "include-background"; /// Command line argument `--log-to`. pub const ARG_LOG_TO: &str = "log-to"; /// Command line argument `--bundled`. @@ -400,6 +402,12 @@ fn migrate() -> Command { .conflicts_with(ARG_MIGRATE_CHECK) .help("Migrate without interactive prompt"), ) + .arg( + Arg::new(ARG_INCLUDE_BACKGROUND) + .long(ARG_INCLUDE_BACKGROUND) + .action(clap::ArgAction::SetTrue) + .help("Whether include background migrations"), + ) } #[cfg(not(target_os = "windows"))] diff --git a/util/app-config/src/lib.rs b/util/app-config/src/lib.rs index d67309f010..bf2540523c 100644 --- a/util/app-config/src/lib.rs +++ b/util/app-config/src/lib.rs @@ -109,12 +109,14 @@ impl Setup { let config = self.config.into_ckb()?; let check = matches.get_flag(cli::ARG_MIGRATE_CHECK); let force = matches.get_flag(cli::ARG_FORCE); + let include_background = matches.get_flag(cli::ARG_INCLUDE_BACKGROUND); Ok(MigrateArgs { config, consensus, check, force, + include_background, }) } diff --git a/util/migrate/src/migrate.rs b/util/migrate/src/migrate.rs index 35d3c3a880..6446d4b37d 100644 --- a/util/migrate/src/migrate.rs +++ b/util/migrate/src/migrate.rs @@ -53,13 +53,13 @@ impl Migrate { /// - Equal: The database version is matched with the executable binary version. /// - Greater: The database version is greater than the matched version of the executable binary. /// Requires upgrade the executable binary. - pub fn check(&self, db: &ReadOnlyDB) -> Ordering { - self.migrations.check(db) + pub fn check(&self, db: &ReadOnlyDB, include_background: bool) -> Ordering { + self.migrations.check(db, include_background) } /// Check whether database requires expensive migrations. - pub fn require_expensive(&self, db: &ReadOnlyDB) -> bool { - self.migrations.expensive(db) + pub fn require_expensive(&self, db: &ReadOnlyDB, include_background: bool) -> bool { + self.migrations.expensive(db, include_background) } /// Check whether the pending migrations are all background migrations. diff --git a/util/migrate/src/tests.rs b/util/migrate/src/tests.rs index 1d48487a01..2bb5c084a0 100644 --- a/util/migrate/src/tests.rs +++ b/util/migrate/src/tests.rs @@ -161,5 +161,5 @@ fn test_mock_migration() { let rdb = mg2.open_read_only_db().unwrap().unwrap(); - assert_eq!(mg2.check(&rdb), std::cmp::Ordering::Equal) + assert_eq!(mg2.check(&rdb, false), std::cmp::Ordering::Equal) } From 2e29e605a1d0ad67d0025d68aa8bf00e439528e6 Mon Sep 17 00:00:00 2001 From: yukang Date: Tue, 20 Feb 2024 11:34:01 +0800 Subject: [PATCH 3/3] fix subcommand migrate issues for background migrations --- ckb-bin/src/subcommand/migrate.rs | 8 +++++++- util/migrate/src/tests.rs | 2 +- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/ckb-bin/src/subcommand/migrate.rs b/ckb-bin/src/subcommand/migrate.rs index e20aeea068..43cca15693 100644 --- a/ckb-bin/src/subcommand/migrate.rs +++ b/ckb-bin/src/subcommand/migrate.rs @@ -15,7 +15,9 @@ pub fn migrate(args: MigrateArgs) -> Result<(), ExitCode> { })?; if let Some(db) = read_only_db { - let db_status = migrate.check(&db, args.include_background); + // if there are only pending background migrations, they will run automatically + // so here we check with `include_background` as true + let db_status = migrate.check(&db, true); if matches!(db_status, Ordering::Greater) { eprintln!( "The database was created by a higher version CKB executable binary \n\ @@ -25,8 +27,12 @@ pub fn migrate(args: MigrateArgs) -> Result<(), ExitCode> { return Err(ExitCode::Failure); } + // `include_background` is default to false + let db_status = migrate.check(&db, args.include_background); if args.check { if matches!(db_status, Ordering::Less) { + // special for bash usage, return 0 means need run migration + // if ckb migrate --check; then ckb migrate --force; fi return Ok(()); } else { return Err(ExitCode::Cli); diff --git a/util/migrate/src/tests.rs b/util/migrate/src/tests.rs index 2bb5c084a0..f8335c6fc0 100644 --- a/util/migrate/src/tests.rs +++ b/util/migrate/src/tests.rs @@ -161,5 +161,5 @@ fn test_mock_migration() { let rdb = mg2.open_read_only_db().unwrap().unwrap(); - assert_eq!(mg2.check(&rdb, false), std::cmp::Ordering::Equal) + assert_eq!(mg2.check(&rdb, true), std::cmp::Ordering::Equal) }