mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
thin: fix volume_list support
Fixing problem, when user sets volume_list and excludes thin pools from activation. In this case pool return 'success' for skipped activation. We need to really check the volume it is actually active to properly to remove queued pool messages. Otherwise the lvm2 and kernel metadata started to go async since lvm2 believed, messages were submitted. Add also better check for threshold when create a new thin volume. In this case we require local activation of thin pool so we are able to check pool fullness.
This commit is contained in:
parent
1ee5e18a7b
commit
0794a10f91
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.110 -
|
Version 2.02.110 -
|
||||||
==================================
|
==================================
|
||||||
|
Fix manipulation with thin-pools which are excluded via volume_list.
|
||||||
Support lv/vgremove -ff to remove thin vols from broken/inactive thin pools.
|
Support lv/vgremove -ff to remove thin vols from broken/inactive thin pools.
|
||||||
Fix typo breaking configure --with-lvm1=shared.
|
Fix typo breaking configure --with-lvm1=shared.
|
||||||
Modify lvresize code to handle raid/mirrors and physical extents.
|
Modify lvresize code to handle raid/mirrors and physical extents.
|
||||||
|
@ -6816,15 +6816,7 @@ static struct logical_volume *_lv_create_an_lv(struct volume_group *vg,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lv_is_active_locally(lvl->lv) &&
|
if ((pool_is_active(lvl->lv) || is_change_activating(lp->activate)) &&
|
||||||
!pool_below_threshold(first_seg(lvl->lv))) {
|
|
||||||
log_error("Cannot create thin volume. Pool \"%s/%s\" "
|
|
||||||
"is filled over the autoextend threshold.",
|
|
||||||
lvl->lv->vg->name, lvl->lv->name);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((lv_is_active(lvl->lv) || is_change_activating(lp->activate)) &&
|
|
||||||
!update_pool_lv(lvl->lv, 1))
|
!update_pool_lv(lvl->lv, 1))
|
||||||
return_NULL;
|
return_NULL;
|
||||||
|
|
||||||
|
@ -307,9 +307,36 @@ uint32_t get_free_pool_device_id(struct lv_segment *thin_pool_seg)
|
|||||||
return max_id;
|
return max_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int _check_pool_create(const struct logical_volume *lv)
|
||||||
|
{
|
||||||
|
const struct lv_thin_message *lmsg;
|
||||||
|
struct lvinfo info;
|
||||||
|
|
||||||
|
dm_list_iterate_items(lmsg, &first_seg(lv)->thin_messages) {
|
||||||
|
if (lmsg->type != DM_THIN_MESSAGE_CREATE_THIN)
|
||||||
|
continue;
|
||||||
|
/* When creating new thin LV, check for size would be needed */
|
||||||
|
if (!lv_info(lv->vg->cmd, lv, 1, &info, 0, 0) ||
|
||||||
|
!info.exists) {
|
||||||
|
log_error("Pool %s needs to be locally active for threshold check.",
|
||||||
|
display_lvname(lv));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (!pool_below_threshold(first_seg(lv))) {
|
||||||
|
log_error("Free space in pool %s is above threshold, new volumes are not allowed.",
|
||||||
|
display_lvname(lv));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
int update_pool_lv(struct logical_volume *lv, int activate)
|
int update_pool_lv(struct logical_volume *lv, int activate)
|
||||||
{
|
{
|
||||||
int monitored;
|
int monitored;
|
||||||
|
int ret = 1;
|
||||||
|
|
||||||
if (!lv_is_thin_pool(lv)) {
|
if (!lv_is_thin_pool(lv)) {
|
||||||
log_error(INTERNAL_ERROR "Updated LV %s is not pool.", lv->name);
|
log_error(INTERNAL_ERROR "Updated LV %s is not pool.", lv->name);
|
||||||
@ -324,10 +351,24 @@ int update_pool_lv(struct logical_volume *lv, int activate)
|
|||||||
if (!lv_is_active(lv)) {
|
if (!lv_is_active(lv)) {
|
||||||
monitored = dmeventd_monitor_mode();
|
monitored = dmeventd_monitor_mode();
|
||||||
init_dmeventd_monitor(DMEVENTD_MONITOR_IGNORE);
|
init_dmeventd_monitor(DMEVENTD_MONITOR_IGNORE);
|
||||||
if (!activate_lv_excl(lv->vg->cmd, lv))
|
if (!activate_lv_excl(lv->vg->cmd, lv)) {
|
||||||
|
init_dmeventd_monitor(monitored);
|
||||||
return_0;
|
return_0;
|
||||||
if (!deactivate_lv(lv->vg->cmd, lv))
|
}
|
||||||
|
if (!lv_is_active(lv)) {
|
||||||
|
init_dmeventd_monitor(monitored);
|
||||||
|
log_error("Cannot activate thin pool %s, perhaps skipped in lvm.conf volume_list?",
|
||||||
|
display_lvname(lv));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(ret = _check_pool_create(lv)))
|
||||||
|
stack;
|
||||||
|
|
||||||
|
if (!deactivate_lv(lv->vg->cmd, lv)) {
|
||||||
|
init_dmeventd_monitor(monitored);
|
||||||
return_0;
|
return_0;
|
||||||
|
}
|
||||||
init_dmeventd_monitor(monitored);
|
init_dmeventd_monitor(monitored);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
@ -337,7 +378,8 @@ int update_pool_lv(struct logical_volume *lv, int activate)
|
|||||||
else if (!resume_lv_origin(lv->vg->cmd, lv)) {
|
else if (!resume_lv_origin(lv->vg->cmd, lv)) {
|
||||||
log_error("Failed to resume %s.", lv->name);
|
log_error("Failed to resume %s.", lv->name);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
} else if (!(ret = _check_pool_create(lv)))
|
||||||
|
stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
dm_list_init(&(first_seg(lv)->thin_messages));
|
dm_list_init(&(first_seg(lv)->thin_messages));
|
||||||
@ -345,7 +387,7 @@ int update_pool_lv(struct logical_volume *lv, int activate)
|
|||||||
if (!vg_write(lv->vg) || !vg_commit(lv->vg))
|
if (!vg_write(lv->vg) || !vg_commit(lv->vg))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
return 1;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int update_thin_pool_params(struct volume_group *vg,
|
int update_thin_pool_params(struct volume_group *vg,
|
||||||
|
Loading…
Reference in New Issue
Block a user