From 35d8fb05017af9ee8514cb317cb37fc2ce5185a9 Mon Sep 17 00:00:00 2001 From: Phil Blundell Date: Tue, 13 Jan 2009 11:51:04 +0000 Subject: - ares__send_query() now varies the retry timeout pseudo-randomly to avoid packet storms when several queries were started at the same time. --- ares/ares_process.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'ares/ares_process.c') diff --git a/ares/ares_process.c b/ares/ares_process.c index 8c25b11da..3aa75cdae 100644 --- a/ares/ares_process.c +++ b/ares/ares_process.c @@ -715,6 +715,7 @@ void ares__send_query(ares_channel channel, struct query *query, { struct send_request *sendreq; struct server_state *server; + int timeplus; server = &channel->servers[query->server]; if (query->using_tcp) @@ -778,9 +779,11 @@ void ares__send_query(ares_channel channel, struct query *query, return; } } + timeplus = channel->timeout << (query->try / channel->nservers); + timeplus = (timeplus * (9 + (rand () & 7))) / 16; query->timeout = *now; ares__timeadd(&query->timeout, - channel->timeout << (query->try / channel->nservers)); + timeplus); /* Keep track of queries bucketed by timeout, so we can process * timeout events quickly. */ -- cgit v1.2.3