mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-22 16:18:28 -05:00
Tcp keep-alive: send three probes before detectin an error.
Otherwise we end with less reliable connections because it's too easy that a single packet gets lost.
This commit is contained in:
parent
98b1a852b4
commit
76a5b21c3a
12
src/anet.c
12
src/anet.c
@ -100,15 +100,19 @@ int anetKeepAlive(char *err, int fd, int interval)
|
||||
return ANET_ERR;
|
||||
}
|
||||
|
||||
/* Send next probes after interval. */
|
||||
val = interval;
|
||||
/* Send next probes after the specified interval. Note that we set the
|
||||
* delay as interval / 3, as we send three probes before detecting
|
||||
* an error (see the next setsockopt call). */
|
||||
val = interval/3;
|
||||
if (val == 0) val = 1;
|
||||
if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPINTVL, &val, sizeof(val)) < 0) {
|
||||
anetSetError(err, "setsockopt TCP_KEEPINTVL: %s\n", strerror(errno));
|
||||
return ANET_ERR;
|
||||
}
|
||||
|
||||
/* Consider the socket in error state after just one missing ACK reply. */
|
||||
val = 1;
|
||||
/* Consider the socket in error state after three we send three ACK
|
||||
* probes without getting a reply. */
|
||||
val = 3;
|
||||
if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPCNT, &val, sizeof(val)) < 0) {
|
||||
anetSetError(err, "setsockopt TCP_KEEPCNT: %s\n", strerror(errno));
|
||||
return ANET_ERR;
|
||||
|
Loading…
Reference in New Issue
Block a user