mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
pvremove: Avoid metadata re-reads & related error messages.
This commit is contained in:
parent
0987f290a7
commit
e97023804a
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.115 -
|
Version 2.02.115 -
|
||||||
=====================================
|
=====================================
|
||||||
|
Avoid excessive re-reading of metadata and related error messages in pvremove.
|
||||||
Check for cmirror availability during cluster mirror creation and activation.
|
Check for cmirror availability during cluster mirror creation and activation.
|
||||||
Add cache_policy and cache_settings reporting fields.
|
Add cache_policy and cache_settings reporting fields.
|
||||||
Add missing recognition for --binary option with {pv,vg,lv}display -C.
|
Add missing recognition for --binary option with {pv,vg,lv}display -C.
|
||||||
|
@ -635,7 +635,9 @@ struct physical_volume *pv_create(const struct cmd_context *cmd,
|
|||||||
|
|
||||||
int pvremove_single(struct cmd_context *cmd, const char *pv_name,
|
int pvremove_single(struct cmd_context *cmd, const char *pv_name,
|
||||||
void *handle __attribute__((unused)), unsigned force_count,
|
void *handle __attribute__((unused)), unsigned force_count,
|
||||||
unsigned prompt);
|
unsigned prompt, struct dm_list *pvslist);
|
||||||
|
int pvremove_many(struct cmd_context *cmd, struct dm_list *pv_names,
|
||||||
|
unsigned force_count, unsigned prompt);
|
||||||
|
|
||||||
int pv_resize_single(struct cmd_context *cmd,
|
int pv_resize_single(struct cmd_context *cmd,
|
||||||
struct volume_group *vg,
|
struct volume_group *vg,
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "label.h"
|
#include "label.h"
|
||||||
#include "archiver.h"
|
#include "archiver.h"
|
||||||
|
#include "lvm-signal.h"
|
||||||
|
|
||||||
static struct pv_segment *_alloc_pv_segment(struct dm_pool *mem,
|
static struct pv_segment *_alloc_pv_segment(struct dm_pool *mem,
|
||||||
struct physical_volume *pv,
|
struct physical_volume *pv,
|
||||||
@ -694,12 +695,11 @@ const char _really_wipe[] =
|
|||||||
* 0 indicates we may not.
|
* 0 indicates we may not.
|
||||||
*/
|
*/
|
||||||
static int pvremove_check(struct cmd_context *cmd, const char *name,
|
static int pvremove_check(struct cmd_context *cmd, const char *name,
|
||||||
unsigned force_count, unsigned prompt)
|
unsigned force_count, unsigned prompt, struct dm_list *pvslist)
|
||||||
{
|
{
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
struct label *label;
|
struct label *label;
|
||||||
struct pv_list *pvl;
|
struct pv_list *pvl;
|
||||||
struct dm_list *pvslist;
|
|
||||||
|
|
||||||
struct physical_volume *pv = NULL;
|
struct physical_volume *pv = NULL;
|
||||||
int r = 0;
|
int r = 0;
|
||||||
@ -720,10 +720,6 @@ static int pvremove_check(struct cmd_context *cmd, const char *name,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
lvmcache_seed_infos_from_lvmetad(cmd);
|
|
||||||
if (!(pvslist = get_pvs(cmd)))
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
dm_list_iterate_items(pvl, pvslist)
|
dm_list_iterate_items(pvl, pvslist)
|
||||||
if (pvl->pv->dev == dev)
|
if (pvl->pv->dev == dev)
|
||||||
pv = pvl->pv;
|
pv = pvl->pv;
|
||||||
@ -765,26 +761,18 @@ static int pvremove_check(struct cmd_context *cmd, const char *name,
|
|||||||
|
|
||||||
r = 1;
|
r = 1;
|
||||||
out:
|
out:
|
||||||
if (pvslist)
|
|
||||||
dm_list_iterate_items(pvl, pvslist)
|
|
||||||
free_pv_fid(pvl->pv);
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pvremove_single(struct cmd_context *cmd, const char *pv_name,
|
int pvremove_single(struct cmd_context *cmd, const char *pv_name,
|
||||||
void *handle __attribute__((unused)), unsigned force_count,
|
void *handle __attribute__((unused)), unsigned force_count,
|
||||||
unsigned prompt)
|
unsigned prompt, struct dm_list *pvslist)
|
||||||
{
|
{
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
struct lvmcache_info *info;
|
struct lvmcache_info *info;
|
||||||
int r = 0;
|
int r = 0;
|
||||||
|
|
||||||
if (!lock_vol(cmd, VG_ORPHANS, LCK_VG_WRITE, NULL)) {
|
if (!pvremove_check(cmd, pv_name, force_count, prompt, pvslist))
|
||||||
log_error("Can't get lock for orphan PVs");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!pvremove_check(cmd, pv_name, force_count, prompt))
|
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (!(dev = dev_cache_get(pv_name, cmd->filter))) {
|
if (!(dev = dev_cache_get(pv_name, cmd->filter))) {
|
||||||
@ -819,10 +807,49 @@ int pvremove_single(struct cmd_context *cmd, const char *pv_name,
|
|||||||
|
|
||||||
r = 1;
|
r = 1;
|
||||||
|
|
||||||
|
out:
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
int pvremove_many(struct cmd_context *cmd, struct dm_list *pv_names,
|
||||||
|
unsigned force_count, unsigned prompt)
|
||||||
|
{
|
||||||
|
int ret = 1;
|
||||||
|
struct dm_list *pvslist = NULL;
|
||||||
|
struct pv_list *pvl;
|
||||||
|
const struct dm_str_list *pv_name;
|
||||||
|
|
||||||
|
if (!lock_vol(cmd, VG_ORPHANS, LCK_VG_WRITE, NULL)) {
|
||||||
|
log_error("Can't get lock for orphan PVs");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
lvmcache_seed_infos_from_lvmetad(cmd);
|
||||||
|
|
||||||
|
if (!(pvslist = get_pvs(cmd))) {
|
||||||
|
ret = 0;
|
||||||
|
goto_out;
|
||||||
|
}
|
||||||
|
|
||||||
|
dm_list_iterate_items(pv_name, pv_names) {
|
||||||
|
if (!pvremove_single(cmd, pv_name->str, NULL, force_count, prompt, pvslist)) {
|
||||||
|
stack;
|
||||||
|
ret = 0;
|
||||||
|
}
|
||||||
|
if (sigint_caught()) {
|
||||||
|
ret = 0;
|
||||||
|
goto_out;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
unlock_vg(cmd, VG_ORPHANS);
|
unlock_vg(cmd, VG_ORPHANS);
|
||||||
|
|
||||||
return r;
|
if (pvslist)
|
||||||
|
dm_list_iterate_items(pvl, pvslist)
|
||||||
|
free_pv_fid(pvl->pv);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pvcreate_single(struct cmd_context *cmd, const char *pv_name,
|
int pvcreate_single(struct cmd_context *cmd, const char *pv_name,
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
#include "lib.h"
|
#include "lib.h"
|
||||||
#include "metadata.h"
|
#include "metadata.h"
|
||||||
#include "lvm-string.h"
|
#include "lvm-string.h"
|
||||||
|
#include "str_list.h"
|
||||||
#include "lvm_misc.h"
|
#include "lvm_misc.h"
|
||||||
#include "lvm2app.h"
|
#include "lvm2app.h"
|
||||||
#include "locking.h"
|
#include "locking.h"
|
||||||
@ -118,8 +119,14 @@ int lvm_pv_remove(lvm_t libh, const char *pv_name)
|
|||||||
int rc = 0;
|
int rc = 0;
|
||||||
struct cmd_context *cmd = (struct cmd_context *)libh;
|
struct cmd_context *cmd = (struct cmd_context *)libh;
|
||||||
struct saved_env e = store_user_env(cmd);
|
struct saved_env e = store_user_env(cmd);
|
||||||
|
struct dm_list pv_names;
|
||||||
|
|
||||||
if (!pvremove_single(cmd, pv_name, NULL, 0, 0))
|
dm_list_init(&pv_names);
|
||||||
|
|
||||||
|
if (!str_list_add(cmd->mem, &pv_names, pv_name))
|
||||||
|
rc = -1;
|
||||||
|
|
||||||
|
if (rc >= 0 && !pvremove_many(cmd, &pv_names, 0, 0))
|
||||||
rc = -1;
|
rc = -1;
|
||||||
|
|
||||||
restore_user_env(&e);
|
restore_user_env(&e);
|
||||||
|
@ -14,3 +14,8 @@ aux prepare_devs 2
|
|||||||
pvcreate "$dev1" "$dev2"
|
pvcreate "$dev1" "$dev2"
|
||||||
pvremove "$dev1" "$dev2" 2>&1 | tee pvremove.txt
|
pvremove "$dev1" "$dev2" 2>&1 | tee pvremove.txt
|
||||||
not grep "No physical" pvremove.txt
|
not grep "No physical" pvremove.txt
|
||||||
|
|
||||||
|
pvcreate "$dev1" "$dev2"
|
||||||
|
vgcreate bla $dev1 $dev2
|
||||||
|
pvremove -ff -y $dev1 $dev2 2>&1 | tee pvremove.txt
|
||||||
|
not grep "device missing" pvremove.txt
|
||||||
|
@ -18,9 +18,9 @@
|
|||||||
int pvremove(struct cmd_context *cmd, int argc, char **argv)
|
int pvremove(struct cmd_context *cmd, int argc, char **argv)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int ret = ECMD_PROCESSED;
|
|
||||||
unsigned force_count;
|
unsigned force_count;
|
||||||
unsigned prompt;
|
unsigned prompt;
|
||||||
|
struct dm_list pv_names;
|
||||||
|
|
||||||
if (!argc) {
|
if (!argc) {
|
||||||
log_error("Please enter a physical volume path");
|
log_error("Please enter a physical volume path");
|
||||||
@ -30,15 +30,16 @@ int pvremove(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
force_count = arg_count(cmd, force_ARG);
|
force_count = arg_count(cmd, force_ARG);
|
||||||
prompt = arg_count(cmd, yes_ARG);
|
prompt = arg_count(cmd, yes_ARG);
|
||||||
|
|
||||||
|
dm_list_init(&pv_names);
|
||||||
|
|
||||||
for (i = 0; i < argc; i++) {
|
for (i = 0; i < argc; i++) {
|
||||||
dm_unescape_colons_and_at_signs(argv[i], NULL, NULL);
|
dm_unescape_colons_and_at_signs(argv[i], NULL, NULL);
|
||||||
if (!pvremove_single(cmd, argv[i], NULL, force_count, prompt)) {
|
if (!str_list_add(cmd->mem, &pv_names, argv[i]))
|
||||||
stack;
|
|
||||||
ret = ECMD_FAILED;
|
|
||||||
}
|
|
||||||
if (sigint_caught())
|
|
||||||
return_ECMD_FAILED;
|
return_ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
if (!pvremove_many(cmd, &pv_names, force_count, prompt))
|
||||||
|
return_ECMD_FAILED;
|
||||||
|
|
||||||
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user