diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-11-30 11:48:06 -0500 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-11-30 11:48:06 -0500 |
commit | 072e194a15e9aa0e75c6723763a69476f4f31b93 (patch) | |
tree | c35b69649e435ee44c850327e33b044b28a2f39f /src/or | |
parent | 30b3229252709eeca054ee06cc6e366226723e24 (diff) | |
parent | 98275743081728b1538f70111c891ea573127e85 (diff) | |
download | tor-072e194a15e9aa0e75c6723763a69476f4f31b93.tar.gz tor-072e194a15e9aa0e75c6723763a69476f4f31b93.zip |
Merge branch 'bug21394_029' into maint-0.2.9
Diffstat (limited to 'src/or')
-rw-r--r-- | src/or/dns.c | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/src/or/dns.c b/src/or/dns.c index 0ad4c0f505..c1e3c3256e 100644 --- a/src/or/dns.c +++ b/src/or/dns.c @@ -1425,14 +1425,31 @@ configure_nameservers(int force) #define SET(k,v) evdns_base_set_option(the_evdns_base, (k), (v)) + // If we only have one nameserver, it does not make sense to back off + // from it for a timeout. Unfortunately, the value for max-timeouts is + // currently clamped by libevent to 255, but it does not hurt to set + // it higher in case libevent gets a patch for this. + // Reducing attempts in the case of just one name server too, because + // it is very likely to be a local one where a network connectivity + // issue should not cause an attempt to fail. if (evdns_base_count_nameservers(the_evdns_base) == 1) { - SET("max-timeouts:", "16"); - SET("timeout:", "10"); + SET("max-timeouts:", "1000000"); + SET("attempts:", "1"); } else { SET("max-timeouts:", "3"); - SET("timeout:", "5"); } + // Elongate the queue of maximum inflight dns requests, so if a bunch + // time out at the resolver (happens commonly with unbound) we won't + // stall every other DNS request. This potentially means some wasted + // CPU as there's a walk over a linear queue involved, but this is a + // much better tradeoff compared to just failing DNS requests because + // of a full queue. + SET("max-inflight:", "8192"); + + // Time out after 5 seconds if no reply. + SET("timeout:", "5"); + if (options->ServerDNSRandomizeCase) SET("randomize-case:", "1"); else |