Implementation of GeoDNS

Posted on 2009-07-09
Medium Priority
Last Modified: 2012-05-07
I would like to  implement geodns in our environment.Please help
Question by:USTRLLC

Expert Comment

ID: 24821469
Dear Sir,

Kindly follow instructions in the below link and everything will work fne with you



Accepted Solution

remeshk earned 2000 total points
ID: 24940848

There are many databases and pieces of code out there that allow you to detect which country (or even city) a visitor to your website is from. Most of this code is intended to allow you to adjust the content of your website. Very useful. Really!
There are instances however where adjusting content is not enough. Sometimes you will want to redirect users to a server that is local to them. This could be because you have lag-sensitive traffic like VoIP of game servers. It could also be that you generate a lot of traffic and local traffic is simply cheaper than transit. Or maybe you have multiple entry points for VPN and email traffic into your corporate network. Whatever it is, the only way to do this transparently is to make sure your DNS hands out the right IP address to your users. Doing this based on ip-country databases is not ideal but it should get you a long way.
I looked around a bit for a way to do this. There are a few special DNS servers for this purpose. There are also some patches for Bind. Im not a fan of either special or patches though, they often imply maintenance.
So I wrote a little command-line script called geobind.php to convert the database provided by Webnet77 to Bind acls. (Requires PHP4 cli version to be installed; make sure to edit variables at the beginning of the script.)
Once you have these acls you can use Binds view functionality to serve different versions of your zone file to different parts of the world. Each zone file would of course point to IP addresses that are local to that specific part of the world.
Imagine you have 3 zone files: one for europe, one for the americas and one for the rest of the world. You simple edit named.conf.local to include the acls for europe and the americas. E.g.:
include "/etc/bind/named.conf.options";
include "/etc/bind/acl-europe_east.inc";
include "/etc/bind/acl-europe_sout.inc";
include "/etc/bind/acl-europe_west.inc";
include "/etc/bind/acl-europe_nort.inc";
include "/etc/bind/acl-america_cari.inc";
include "/etc/bind/acl-america_cent.inc";
include "/etc/bind/acl-america_nort.inc";
include "/etc/bind/acl-america_sout.inc";
Next you create seperate views. One for europe, one for the americas and one for everyone else.
view "europe" {
  match-clients {
  zone "peen.net" {
    type master;
    file "/etc/bind/europe/db.peen.net";
view "americas" {
  match-clients {
  zone "peen.net" {
    type master;
    file "/etc/bind/americas/db.peen.net";
view "others" {
  match-clients { any; };
  zone "peen.net" {
    type master;
    file "/etc/bind/others/db.peen.net";
Reload Bind and see what happens!  
peen:~# rndc reload

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

This article explains how to use the rsync command to create backups and sync data across hosts. Rsync is a very useful command that is often used to copy data, make backups, migrate hosts, and bridge the gap between site staging and production envi…
Can you run Linux on a Windows system?  Yep.  Here's how.
Learn several ways to interact with files and get file information from the bash shell. ls lists the contents of a directory: Using the -a flag displays hidden files: Using the -l flag formats the output in a long list: The file command gives us mor…
This demo shows you how to set up the containerized NetScaler CPX with NetScaler Management and Analytics System in a non-routable Mesos/Marathon environment for use with Micro-Services applications.

607 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question