mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
lvmlockd: improve error message about missing global lock
If the VG holding the global lock is removed, we can indicate that as the reason for not being able to acquire the global lock in subsequent error messages, and can suggest enabling the global lock in another VG. (This helpful error message will go away if the global lock is enabled in another VG, or if lvmlockd is restarted.)
This commit is contained in:
parent
1efb1c2343
commit
d0e15b86b5
@ -1654,6 +1654,9 @@ static int res_able(struct lockspace *ls, struct resource *r,
|
|||||||
}
|
}
|
||||||
|
|
||||||
rv = lm_able_gl_sanlock(ls, act->op == LD_OP_ENABLE);
|
rv = lm_able_gl_sanlock(ls, act->op == LD_OP_ENABLE);
|
||||||
|
|
||||||
|
if (!rv && (act->op == LD_OP_ENABLE))
|
||||||
|
gl_vg_removed = 0;
|
||||||
out:
|
out:
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
@ -2627,8 +2630,10 @@ out_act:
|
|||||||
|
|
||||||
if (free_vg && ls->sanlock_gl_enabled && act_op_free) {
|
if (free_vg && ls->sanlock_gl_enabled && act_op_free) {
|
||||||
pthread_mutex_lock(&lockspaces_mutex);
|
pthread_mutex_lock(&lockspaces_mutex);
|
||||||
if (other_sanlock_vgs_exist(ls))
|
if (other_sanlock_vgs_exist(ls)) {
|
||||||
act_op_free->flags |= LD_AF_WARN_GL_REMOVED;
|
act_op_free->flags |= LD_AF_WARN_GL_REMOVED;
|
||||||
|
gl_vg_removed = 1;
|
||||||
|
}
|
||||||
pthread_mutex_unlock(&lockspaces_mutex);
|
pthread_mutex_unlock(&lockspaces_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3668,7 +3673,7 @@ static int client_send_result(struct client *cl, struct action *act)
|
|||||||
if (act->flags & LD_AF_DUP_GL_LS)
|
if (act->flags & LD_AF_DUP_GL_LS)
|
||||||
strcat(result_flags, "DUP_GL_LS,");
|
strcat(result_flags, "DUP_GL_LS,");
|
||||||
|
|
||||||
if (act->flags & LD_AF_WARN_GL_REMOVED)
|
if ((act->flags & LD_AF_WARN_GL_REMOVED) || gl_vg_removed)
|
||||||
strcat(result_flags, "WARN_GL_REMOVED,");
|
strcat(result_flags, "WARN_GL_REMOVED,");
|
||||||
|
|
||||||
if (act->op == LD_OP_INIT) {
|
if (act->op == LD_OP_INIT) {
|
||||||
|
@ -320,6 +320,7 @@ static inline int list_empty(const struct list_head *head)
|
|||||||
EXTERN int gl_type_static;
|
EXTERN int gl_type_static;
|
||||||
EXTERN int gl_use_dlm;
|
EXTERN int gl_use_dlm;
|
||||||
EXTERN int gl_use_sanlock;
|
EXTERN int gl_use_sanlock;
|
||||||
|
EXTERN int gl_vg_removed;
|
||||||
EXTERN char gl_lsname_dlm[MAX_NAME+1];
|
EXTERN char gl_lsname_dlm[MAX_NAME+1];
|
||||||
EXTERN char gl_lsname_sanlock[MAX_NAME+1];
|
EXTERN char gl_lsname_sanlock[MAX_NAME+1];
|
||||||
EXTERN int global_dlm_lockspace_exists;
|
EXTERN int global_dlm_lockspace_exists;
|
||||||
|
@ -969,6 +969,7 @@ int lockd_start_vg(struct cmd_context *cmd, struct volume_group *vg, int start_i
|
|||||||
{
|
{
|
||||||
char uuid[64] __attribute__((aligned(8)));
|
char uuid[64] __attribute__((aligned(8)));
|
||||||
daemon_reply reply;
|
daemon_reply reply;
|
||||||
|
uint32_t lockd_flags = 0;
|
||||||
int host_id = 0;
|
int host_id = 0;
|
||||||
int result;
|
int result;
|
||||||
int ret;
|
int ret;
|
||||||
@ -1018,13 +1019,16 @@ int lockd_start_vg(struct cmd_context *cmd, struct volume_group *vg, int start_i
|
|||||||
"opts = %s", start_init ? "start_init" : "none",
|
"opts = %s", start_init ? "start_init" : "none",
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
if (!_lockd_result(reply, &result, NULL)) {
|
if (!_lockd_result(reply, &result, &lockd_flags)) {
|
||||||
ret = 0;
|
ret = 0;
|
||||||
result = -ELOCKD;
|
result = -ELOCKD;
|
||||||
} else {
|
} else {
|
||||||
ret = (result < 0) ? 0 : 1;
|
ret = (result < 0) ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (lockd_flags & LD_RF_WARN_GL_REMOVED)
|
||||||
|
cmd->lockd_gl_removed = 1;
|
||||||
|
|
||||||
switch (result) {
|
switch (result) {
|
||||||
case 0:
|
case 0:
|
||||||
log_print_unless_silent("VG %s starting %s lockspace", vg->name, vg->lock_type);
|
log_print_unless_silent("VG %s starting %s lockspace", vg->name, vg->lock_type);
|
||||||
@ -1140,6 +1144,11 @@ int lockd_start_wait(struct cmd_context *cmd)
|
|||||||
|
|
||||||
daemon_reply_destroy(reply);
|
daemon_reply_destroy(reply);
|
||||||
|
|
||||||
|
if (cmd->lockd_gl_removed) {
|
||||||
|
log_error("Missing global lock: global lock was lost by removing a previous VG.");
|
||||||
|
log_error("To enable the global lock in another VG, see lvmlockctl --gl-enable.");
|
||||||
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1556,6 +1565,12 @@ int lockd_gl(struct cmd_context *cmd, const char *def_mode, uint32_t flags)
|
|||||||
goto allow;
|
goto allow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((lockd_flags & LD_RF_NO_GL_LS) && (lockd_flags & LD_RF_WARN_GL_REMOVED)) {
|
||||||
|
log_warn("Skipping global lock: VG with global lock was removed");
|
||||||
|
force_cache_update = 1;
|
||||||
|
goto allow;
|
||||||
|
}
|
||||||
|
|
||||||
if ((lockd_flags & LD_RF_NO_GL_LS) || (lockd_flags & LD_RF_NO_LOCKSPACES)) {
|
if ((lockd_flags & LD_RF_NO_GL_LS) || (lockd_flags & LD_RF_NO_LOCKSPACES)) {
|
||||||
log_warn("Skipping global lock: lockspace not found or started");
|
log_warn("Skipping global lock: lockspace not found or started");
|
||||||
force_cache_update = 1;
|
force_cache_update = 1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user