From owner-freebsd-hackers Sun May 12 22:28:25 2002 Delivered-To: freebsd-hackers@freebsd.org Received: from swan.prod.itd.earthlink.net (swan.mail.pas.earthlink.net [207.217.120.123]) by hub.freebsd.org (Postfix) with ESMTP id 854DC37B401 for ; Sun, 12 May 2002 22:28:22 -0700 (PDT) Received: from pool0365.cvx40-bradley.dialup.earthlink.net ([216.244.43.110] helo=mindspring.com) by swan.prod.itd.earthlink.net with esmtp (Exim 3.33 #2) id 1778Nc-0001d0-00; Sun, 12 May 2002 22:28:17 -0700 Message-ID: <3CDF4ED3.BC16D3F9@mindspring.com> Date: Sun, 12 May 2002 22:27:47 -0700 From: Terry Lambert X-Mailer: Mozilla 4.7 [en]C-CCK-MCD {Sony} (Win98; U) X-Accept-Language: en MIME-Version: 1.0 To: Peter Haight Cc: Bernd Walter , hackers@freebsd.org Subject: Re: gethostbyname2 and AF_INET6 References: <200205122016.g4CKGlUn048082@wartch.sapros.com> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG Peter Haight wrote: > >www.vanguard.com has a broken DNS implementation. > >Find out the zone administrator via SOA record or whois and complain. > >RFC requires the behavour you saw with google. > > Ok. The thing is that there are a lot of these sites. Watching the log on > the other side of my DNS server it looks like it is sending requests to > vanguard's dns server, but not getting any replies. Is there some way I can > lower the timeout for IPV6 DNS lookups or maybe disable them? Or is there > some change I can make to mozilla to minimize the impact of sites like > these? > > Hmm. Looking at the FreeBSD resolver code, it doesn't look like there is > some convenient way to do this. Maybe something like, try the AAAA lookup, > but if we don't get any reply in a short timeout, try an A lookup. If we get > a reply to that, then log the site as probably not conforming to the RFC. The best answer is to do what Bernd said, and get the server fixed, since it's an RFC non-conforming server. If you can't do that, the best thing to do on the client side is to do a concurrent IPv6 and IPv4 lookup, and then if the IPv6 times out, take the IPv4 answer. Basically, this means you will have to live with the IPv6 timeout period, no matter what, but at least it won't stack on top of an IPv4 timeout. The best concurrent resolver library is the one that ships with the current version of bind. FreeBSD's resolver library is older than this, and not concurrent, because it's integrated into libc, and not in a seperate libresolv, which makes it hard to upgrade. For an individual application, like the Mozilla you said you were using in your first posting, you can link the bond supplied libresolv before libc, and that will get the new resolver library before the libc version (you will also need to point the compiler at the newer header files, via "-I", to get the newer behaviour). I'm not sure that Mozilla is aware of the asyncronois interface, if they are in the compilation scope; I'd be surprised if it knew about IPv6 but not about the async interfaces. Good luck. -- Terry To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message