mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +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:
parent
2c42f60890
commit
52aa3dbcab
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user