1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-03 05:18:29 +03:00

lvconvert: tune cache-pool zeroing

Follow-up to 27a767d5e8.
Tunning behavior in a way we always prompt when option --zero is NOT specified.
Without -Z lvm expects user wants to 'reset' cache-pool metadata
(they could have been splitted from some cached LV)

If user doesn't want to zero metadata he needs to specify -Zn.

User may also avoid prompting for zeroing by using -Zy for
cache-pool (basically equals using --yes  without -Z being given)
(unlike full convert case, there is no cache-pool being converted,
so there is not 'uncoditional' prompt in this case).
This commit is contained in:
Zdenek Kabelac 2016-07-23 21:17:56 +02:00
parent 5636bfd83d
commit 3c377f8334
2 changed files with 17 additions and 13 deletions

View File

@ -5,7 +5,7 @@ Version 2.02.162 -
Improve lvconvert --trackchanges validation to require --splitmirrors 1. Improve lvconvert --trackchanges validation to require --splitmirrors 1.
Add note about lastlog built-in command to lvm man page. Add note about lastlog built-in command to lvm man page.
Fix unrecognised segtype flag message. Fix unrecognised segtype flag message.
lvconvert reuse cachepool metadade now ONLY with -Zn and clear otherwise. lvconvert not clears cache pool metadata ONLY with -Zn.
Enabled lvconvert --uncache to work with partial VG. Enabled lvconvert --uncache to work with partial VG.
Version 2.02.161 - 15th July 2016 Version 2.02.161 - 15th July 2016

View File

@ -2998,24 +2998,28 @@ static int _lvconvert_pool(struct cmd_context *cmd,
return_0; return_0;
if (lp->cache) { if (lp->cache) {
/* Check is user has not requested -Zn */ /* Check is user requested zeroing logic via [-Z y|n] */
if (!arg_int_value(cmd, zero_ARG, 1)) { if (!arg_is_set(cmd, zero_ARG)) {
/* Note: requires rather deep know-how to skip zeroing /* Note: requires rather deep know-how to skip zeroing */
* so show major warnings */
log_warn("WARNING: Reusing old cache pool metadata %s to "
"for volume caching.",
display_lvname(pool_lv));
log_warn("THIS MAY DESTROY YOUR DATA (filesystem etc.)");
if (!lp->yes && if (!lp->yes &&
yes_no_prompt("Do you really want to keep old metadata for " yes_no_prompt("Do you want wipe existing metadata of "
"cache pool volume %s? [y/n]: ", "cache pool volume %s? [y/n]: ",
display_lvname(pool_lv)) == 'n') { display_lvname(pool_lv)) == 'n') {
log_error("Conversion aborted."); log_error("Conversion aborted.");
log_error("To preserve cache metadata add option \"--zero n\".");
log_warn("WARNING: Reusing mismatched cache pool metadata "
"MAY DESTROY YOUR DATA!");
return 0; return 0;
} }
} else if (!wipe_cache_pool(pool_lv)) /* Wiping confirmed, go ahead */
return_0; if (!wipe_cache_pool(pool_lv))
return_0;
} else if (arg_int_value(cmd, zero_ARG, 0)) {
if (!wipe_cache_pool(pool_lv)) /* Wipe according to -Z y|n */
return_0;
} else
log_warn("WARNING: Reusing cache pool metadata %s "
"for volume caching.", display_lvname(pool_lv));
} }
if (lp->thin || lp->cache) if (lp->thin || lp->cache)