Changed ping behaviour (backwards compatible). If we don't have any data

to send, we don't need to check if the connection is still alive.
Furthermore, if we receive any kind of data from the other end, we know
it's alive, so we don't need to check it either. So, PING requests are
only sent if we send packets but there is no response.
This commit is contained in:
Guus Sliepen 2000-05-14 13:02:20 +00:00
parent ee96ccabbb
commit e20e143f1e
2 changed files with 43 additions and 43 deletions

View file

@ -51,8 +51,6 @@ int total_tap_out = 0;
int total_socket_in = 0; int total_socket_in = 0;
int total_socket_out = 0; int total_socket_out = 0;
time_t last_ping_time = 0;
/* The global list of existing connections */ /* The global list of existing connections */
conn_list_t *conn_list = NULL; conn_list_t *conn_list = NULL;
conn_list_t *myself = NULL; conn_list_t *myself = NULL;
@ -107,6 +105,8 @@ cp
} }
total_socket_out += r; total_socket_out += r;
cl->want_ping = 1;
cp cp
return 0; return 0;
} }
@ -123,6 +123,9 @@ cp
syslog(LOG_ERR, "Can't write to tap device: %m"); syslog(LOG_ERR, "Can't write to tap device: %m");
else else
total_tap_out += lenin; total_tap_out += lenin;
cl->want_ping = 0;
cl->last_ping_time = time(NULL);
cp cp
return 0; return 0;
} }
@ -546,7 +549,7 @@ int setup_network_connections(void)
config_t const *cfg; config_t const *cfg;
cp cp
if((cfg = get_config_val(pingtimeout)) == NULL) if((cfg = get_config_val(pingtimeout)) == NULL)
timeout = 10; timeout = 5;
else else
timeout = cfg->data.val; timeout = cfg->data.val;
@ -692,6 +695,8 @@ cp
p->meta_socket = sfd; p->meta_socket = sfd;
p->status.meta = 1; p->status.meta = 1;
p->buflen = 0; p->buflen = 0;
p->last_ping_time = time(NULL);
p->want_ping = 0;
syslog(LOG_NOTICE, "Connection from %s:%d", p->hostname, htons(ci.sin_port)); syslog(LOG_NOTICE, "Connection from %s:%d", p->hostname, htons(ci.sin_port));
@ -826,52 +831,41 @@ cp
} }
/* /*
send out a ping request to all active Check if the other end is active.
connections If we have sent packets, but didn't receive any,
then possibly the other end is dead. We send a
PING request over the meta connection. If the other
end does not reply in time, we consider them dead
and close the connection.
*/ */
int send_broadcast_ping(void) int check_dead_connections(void)
{ {
conn_list_t *p; conn_list_t *p;
time_t now;
cp cp
now = time(NULL);
for(p = conn_list; p != NULL; p = p->next) for(p = conn_list; p != NULL; p = p->next)
{ {
if(p->status.remove) if(p->status.remove)
continue; continue;
if(p->status.active && p->status.meta) if(p->status.active && p->status.meta)
{ {
if(send_ping(p)) if(p->last_ping_time + timeout < now)
terminate_connection(p); if(p->status.pinged && !p->status.got_pong)
else {
{ syslog(LOG_INFO, "%s (" IP_ADDR_S ") didn't respond to ping",
p->status.pinged = 1; p->hostname, IP_ADDR_V(p->vpn_ip));
p->status.got_pong = 0; p->status.timeout = 1;
} terminate_connection(p);
} }
} else if(p->want_ping)
{
last_ping_time = time(NULL); send_ping(p);
cp p->last_ping_time = now;
return 0; p->status.pinged = 1;
} p->status.get_pong = 0;
}
/* }
end all connections that did not respond
to the ping probe in time
*/
int check_dead_connections(void)
{
conn_list_t *p;
cp
for(p = conn_list; p != NULL; p = p->next)
{
if(p->status.remove)
continue;
if(p->status.active && p->status.meta && p->status.pinged && !p->status.got_pong)
{
syslog(LOG_INFO, "%s (" IP_ADDR_S ") didn't respond to ping",
p->hostname, IP_ADDR_V(p->vpn_ip));
p->status.timeout = 1;
terminate_connection(p);
} }
} }
cp cp
@ -989,6 +983,9 @@ cp
break; break;
} }
} }
cl->last_ping_time = time(NULL);
cl->want_ping = 0;
cp cp
return 0; return 0;
} }
@ -1100,8 +1097,9 @@ void main_loop(void)
fd_set fset; fd_set fset;
struct timeval tv; struct timeval tv;
int r; int r;
time_t last_ping_check;
cp cp
last_ping_time = time(NULL); last_ping_check = time(NULL);
for(;;) for(;;)
{ {
@ -1119,11 +1117,11 @@ cp
return; return;
} }
if(r == 0 || last_ping_time + timeout < time(NULL)) if(last_ping_check + timeout < time(NULL))
/* Timeout... hm... something might be wrong. */ /* Let's check if everybody is still alive */
{ {
check_dead_connections(); check_dead_connections();
send_broadcast_ping(); last_ping_check = time(NULL);
continue; continue;
} }

View file

@ -115,6 +115,8 @@ typedef struct conn_list_t {
char buffer[MAXBUFSIZE+1]; /* metadata input buffer */ char buffer[MAXBUFSIZE+1]; /* metadata input buffer */
int buflen; /* bytes read into buffer */ int buflen; /* bytes read into buffer */
int reqlen; /* length of first request in buffer */ int reqlen; /* length of first request in buffer */
time_t last_ping_time; /* last time we saw some activity from the other end */
int want_ping; /* 0 if there's no need to check for activity */
struct conn_list_t *nexthop; /* nearest meta-hop in this direction */ struct conn_list_t *nexthop; /* nearest meta-hop in this direction */
struct conn_list_t *next; /* after all, it's a list of connections */ struct conn_list_t *next; /* after all, it's a list of connections */
} conn_list_t; } conn_list_t;