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

cmirrord: Clean-up stray warning message

cmirrord polls for messages on the kernel and cluster interfaces.
Sometimes it is possible for messages to be received on the cluster
interface and be waiting for processing while the node is in the
process of leaving the cluster group.  When this happens, the
messages received on the cluster interface are attempted to be
dispatched, but an error is returned because the connection is no
longer valid.  It is a harmless situation.  So, if we get the
specific error (CS_ERR_BAD_HANDLE) and we know that we have left
the group, then simply don't print the message.
This commit is contained in:
Jonathan Brassow 2014-03-05 10:44:20 -06:00
parent 2c42f60890
commit 52aa3dbcab

View File

@ -984,9 +984,16 @@ static int do_cluster_work(void *data __attribute__((unused)))
dm_list_iterate_items_safe(entry, tmp, &clog_cpg_list) { dm_list_iterate_items_safe(entry, tmp, &clog_cpg_list) {
r = cpg_dispatch(entry->handle, CS_DISPATCH_ALL); r = cpg_dispatch(entry->handle, CS_DISPATCH_ALL);
if (r != CS_OK) if (r != CS_OK) {
if ((entry->cpg_state == INVALID) &&
(entry->state == LEAVING) &&
(r == CS_ERR_BAD_HANDLE))
/* It's ok if we've left the cluster */
r = CS_OK;
else
LOG_ERROR("cpg_dispatch failed: %s", LOG_ERROR("cpg_dispatch failed: %s",
str_ais_error(r)); str_ais_error(r));
}
if (entry->free_me) { if (entry->free_me) {
free(entry); free(entry);