mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-20 03:25:18 +00:00
client rpc: Send keepalive requests from IO event loop
In addition to keepalive responses, we also need to send keepalive requests from client IO loop to properly detect dead connection in case a libvirt API is called from the main loop, which prevents any timers to be called. (cherry picked from commit 4d971dc7ef1a9d0dc830c243b5731e862ad0eb5c)
This commit is contained in:
parent
f8e651117f
commit
e9c00cbc63
@ -1272,6 +1272,7 @@ static int virNetClientIOEventLoop(virNetClientPtr client,
|
|||||||
char ignore;
|
char ignore;
|
||||||
sigset_t oldmask, blockedsigs;
|
sigset_t oldmask, blockedsigs;
|
||||||
int timeout = -1;
|
int timeout = -1;
|
||||||
|
virNetMessagePtr msg = NULL;
|
||||||
|
|
||||||
/* If we have existing SASL decoded data we don't want to sleep in
|
/* If we have existing SASL decoded data we don't want to sleep in
|
||||||
* the poll(), just check if any other FDs are also ready.
|
* the poll(), just check if any other FDs are also ready.
|
||||||
@ -1285,6 +1286,10 @@ static int virNetClientIOEventLoop(virNetClientPtr client,
|
|||||||
if (thiscall->nonBlock)
|
if (thiscall->nonBlock)
|
||||||
timeout = 0;
|
timeout = 0;
|
||||||
|
|
||||||
|
/* Limit timeout so that we can send keepalive request in time */
|
||||||
|
if (timeout == -1)
|
||||||
|
timeout = virKeepAliveTimeout(client->keepalive);
|
||||||
|
|
||||||
fds[0].events = fds[0].revents = 0;
|
fds[0].events = fds[0].revents = 0;
|
||||||
fds[1].events = fds[1].revents = 0;
|
fds[1].events = fds[1].revents = 0;
|
||||||
|
|
||||||
@ -1330,6 +1335,13 @@ static int virNetClientIOEventLoop(virNetClientPtr client,
|
|||||||
|
|
||||||
virNetClientLock(client);
|
virNetClientLock(client);
|
||||||
|
|
||||||
|
if (virKeepAliveTrigger(client->keepalive, &msg)) {
|
||||||
|
client->wantClose = true;
|
||||||
|
} else if (msg && virNetClientQueueNonBlocking(client, msg) < 0) {
|
||||||
|
VIR_WARN("Could not queue keepalive request");
|
||||||
|
virNetMessageFree(msg);
|
||||||
|
}
|
||||||
|
|
||||||
/* If we have existing SASL decoded data, pretend
|
/* If we have existing SASL decoded data, pretend
|
||||||
* the socket became readable so we consume it
|
* the socket became readable so we consume it
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user