Saturday, January 29, 2011

google.com different IP in different countries. How?

If you ping google.com from different countries you will get replies from local google servers. How does that work? Can a DNS record have multiple A addresses? Could someone point me to the technology they use to do that?

Update. OK, so Google's DNS server gives out a different IP based on the location. But, as Alexandre Jasmin pointed out, how do they track the location? Surely their DNS won't ever see your IP address. Is the server querying Google's DNS guaranteed to be from the location it represents?

  • I believe it's called CDN

    From silent
  • A DNS name may have multiple A records, clients may then choose any record and use that address.

    That's not the entire truth though, Google's DNS servers are also giving you different A records depending on your IP address so that you may use a server close to you.

    Billy ONeal : Damn you! Beat me by less than a min :) +1
    HeavyWave : So DNS server must support this specifically? Are there any hosting companies that provide this?
    Alexandre Jasmin : They can't generally do this depending on *your* IP address right? DNS requests typically go through your ISP DNS server first so the DNS servers of Google won't in fact see *your* IP
    Martin : @Alexandre: yes, but it usually works anyway since your ISP's resolver is most likely in the same part of the world as you are. It won't work for clients using OpenDNS and similar services though.
    Alexandre Jasmin : @Martin I agree that *it usually works anyway*. As for OpenDNS I think they use anycast routing so it could work as well depending on how they pass along the request.
    From Martin
  • Google uses Round Robin DNS. Essentially, Google's DNS server changes the address it gives you based on your location.

    Billy ONeal : @Tim Green -- good point. The idea is the same though.
  • Depending on the IP that requests the lookup, it will depend on what results they give.

    Something like this: http://www.ip2location.com/ip2location-bind-dns.aspx

  • I think it is using Anycast IP addressing for the DNS servers. So depending on which part of the world you are, a different DNS server (although with the same IP address) will answer your query. And that server will know which IP address is the best for your location.

    Chris S : +1, Correct, Google (and many other large networks) use Anycast to route requests to the closest server. Multiple servers have the same IP, and you get the closest according to the AS routes in BGP.

0 comments:

Post a Comment