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

lvmlockd: always try to connect to lvmetad

Reconnect to lvmetad if either the send fails (e.g. lvmetad
was restarted since lvmlockd last connected), or if no
lvmetad connection exists (e.g. lvmetad was started after
lvmlockd so no previous connection existed.)
This commit is contained in:
David Teigland 2016-06-20 13:47:26 -05:00
parent b12961e7eb
commit 47a29f6b2e

View File

@ -1013,6 +1013,7 @@ static daemon_reply send_lvmetad(const char *id, ...)
daemon_reply reply; daemon_reply reply;
va_list ap; va_list ap;
int retries = 0; int retries = 0;
int err;
va_start(ap, id); va_start(ap, id);
@ -1022,20 +1023,27 @@ static daemon_reply send_lvmetad(const char *id, ...)
*/ */
pthread_mutex_lock(&lvmetad_mutex); pthread_mutex_lock(&lvmetad_mutex);
retry: retry:
if (!lvmetad_connected) {
lvmetad_handle = lvmetad_open(NULL);
if (lvmetad_handle.error || lvmetad_handle.socket_fd < 0) {
err = lvmetad_handle.error ?: lvmetad_handle.socket_fd;
pthread_mutex_unlock(&lvmetad_mutex);
log_error("lvmetad_open reconnect error %d", err);
memset(&reply, 0, sizeof(reply));
reply.error = err;
return reply;
} else {
log_debug("lvmetad reconnected");
lvmetad_connected = 1;
}
}
reply = daemon_send_simple_v(lvmetad_handle, id, ap); reply = daemon_send_simple_v(lvmetad_handle, id, ap);
/* lvmetad may have been restarted */ /* lvmetad may have been restarted */
if ((reply.error == ECONNRESET) && (retries < 2)) { if ((reply.error == ECONNRESET) && (retries < 2)) {
daemon_close(lvmetad_handle); daemon_close(lvmetad_handle);
lvmetad_connected = 0; lvmetad_connected = 0;
lvmetad_handle = lvmetad_open(NULL);
if (lvmetad_handle.error || lvmetad_handle.socket_fd < 0) {
log_error("lvmetad_open reconnect error %d", lvmetad_handle.error);
} else {
log_debug("lvmetad reconnected");
lvmetad_connected = 1;
}
retries++; retries++;
goto retry; goto retry;
} }
@ -1240,10 +1248,6 @@ static int res_lock(struct lockspace *ls, struct resource *r, struct action *act
rv = -EREMOVED; rv = -EREMOVED;
} }
if (!lvmetad_connected && inval_meta)
log_debug("S %s R %s res_lock no lvmetad connection to invalidate",
ls->name, r->name);
/* /*
* r is vglk: tell lvmetad to set the vg invalid * r is vglk: tell lvmetad to set the vg invalid
* flag, and provide the new r_version. If lvmetad finds * flag, and provide the new r_version. If lvmetad finds
@ -1259,7 +1263,7 @@ static int res_lock(struct lockspace *ls, struct resource *r, struct action *act
* caches, and tell lvmetad to set global invalid to 0. * caches, and tell lvmetad to set global invalid to 0.
*/ */
if (lvmetad_connected && inval_meta && (r->type == LD_RT_VG)) { if (inval_meta && (r->type == LD_RT_VG)) {
daemon_reply reply; daemon_reply reply;
char *uuid; char *uuid;
@ -1283,7 +1287,7 @@ static int res_lock(struct lockspace *ls, struct resource *r, struct action *act
daemon_reply_destroy(reply); daemon_reply_destroy(reply);
} }
if (lvmetad_connected && inval_meta && (r->type == LD_RT_GL)) { if (inval_meta && (r->type == LD_RT_GL)) {
daemon_reply reply; daemon_reply reply;
log_debug("S %s R %s res_lock set lvmetad global invalid", log_debug("S %s R %s res_lock set lvmetad global invalid",