1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

pvmove: change locking on finish

This commit is contained in:
Zdenek Kabelac 2017-11-14 20:53:55 +01:00
parent 9d04ecc7b3
commit a25f9b2106
2 changed files with 19 additions and 37 deletions

View File

@ -1,5 +1,6 @@
Version 2.02.177 - Version 2.02.177 -
==================================== ====================================
Ehnance pvmove locking.
Deactivate activated LVs on error path when pvmove activation fails. Deactivate activated LVs on error path when pvmove activation fails.
Add "io" to log/debug_classes for logging low-level I/O. Add "io" to log/debug_classes for logging low-level I/O.
Eliminate redundant nested VG metadata in VG struct. Eliminate redundant nested VG metadata in VG struct.

View File

@ -92,6 +92,8 @@ int pvmove_update_metadata(struct cmd_context *cmd, struct volume_group *vg,
int pvmove_finish(struct cmd_context *cmd, struct volume_group *vg, int pvmove_finish(struct cmd_context *cmd, struct volume_group *vg,
struct logical_volume *lv_mirr, struct dm_list *lvs_changed) struct logical_volume *lv_mirr, struct dm_list *lvs_changed)
{ {
struct lv_list *lvl;
struct logical_volume *holder;
int r = 1; int r = 1;
if (!dm_list_empty(lvs_changed) && if (!dm_list_empty(lvs_changed) &&
@ -101,48 +103,27 @@ int pvmove_finish(struct cmd_context *cmd, struct volume_group *vg,
return 0; return 0;
} }
/* Store metadata without dependencies on mirror segments */ if (!lv_update_and_reload(lv_mirr))
if (!vg_write(vg)) { return_0;
log_error("ABORTING: Failed to write new data locations "
"to disk."); /* Takes locks and resumed volumes (should be still suspended, but preloaded) */
dm_list_iterate_items(lvl, lvs_changed) {
holder = (struct logical_volume *) lv_lock_holder(lvl->lv);
if (!resume_lv(cmd, holder)) {
log_error("Failed to reactivate logical volume %s.",
display_lvname(holder));
r = 0; /* But try to resume as much as we can */
}
}
if (!r)
return 0; return 0;
}
/* Suspend LVs changed (implicitly suspends lv_mirr) */
if (!suspend_lvs(cmd, lvs_changed, vg)) {
log_error("ABORTING: Locking LVs to remove temporary mirror failed");
if (!revert_lv(cmd, lv_mirr))
stack;
return 0;
}
/* Store metadata without dependencies on mirror segments */
if (!vg_commit(vg)) {
log_error("ABORTING: Failed to write new data locations "
"to disk.");
if (!revert_lv(cmd, lv_mirr))
stack;
if (!revert_lvs(cmd, lvs_changed))
stack;
return 0;
}
/* Unsuspend LVs */
if (!resume_lvs(cmd, lvs_changed))
stack;
/* Release mirror LV. (No pending I/O because it's been suspended.) */
if (!activate_lv_excl_local(cmd, lv_mirr)) {
log_error("Unable to reactivate logical volume \"%s\"",
lv_mirr->name);
r = 0;
}
/* Deactivate mirror LV */ /* Deactivate mirror LV */
if (!deactivate_lv(cmd, lv_mirr)) { if (!deactivate_lv(cmd, lv_mirr)) {
log_error("ABORTING: Unable to deactivate temporary logical " log_error("ABORTING: Unable to deactivate temporary logical "
"volume %s.", display_lvname(lv_mirr)); "volume %s.", display_lvname(lv_mirr));
r = 0; return 0;
} }
log_verbose("Removing temporary pvmove LV"); log_verbose("Removing temporary pvmove LV");
@ -162,5 +143,5 @@ int pvmove_finish(struct cmd_context *cmd, struct volume_group *vg,
/* FIXME backup positioning */ /* FIXME backup positioning */
backup(vg); backup(vg);
return r; return 1;
} }