nginx geo 模块实现全局负载均衡

来源:互联网 发布:家装电路设计软件 编辑:程序博客网 时间:2024/04/30 19:21
 大家都知道 智能DNS吧?根据来访IP,DNS解析到不同的服务器上,今天仔细看了下nginx 的模块,也有这个功能!http://wiki.nginx.org/NginxHttpGeoModule
下面我就跟我一起来体验一下吧!
 
server1  : 192.168.6.101
server2  :  192.168.6.102
server3  :  192.168.6.121
 
测试机1 IP:192.168.6.2
测试机2 IP:192.168.6.8
测试机3 IP:192.168.6.189
 
1.在每台server上都编译安装 nginx ,我就不多说了!
server1,与server2 的配置我没有改动~只把他的主页改一下,这样有利于测试!
server1 :
shell $> cd /usr/local/nginx/html
shell $> rm index.html
shell $> echo "192.168.6.101" > index.html
 
server2:
shell $> cd /usr/local/nginx/html
shell $> rm index.html
shell $> echo "192.168.6.102" > index.html
 
把他们的服务都起来
shell $> /usr/local/nginx/sbin/nginx
 
2.修改 server3 的配置`
 
shell $> cd /usr/local/nginx/conf/
shell $> vim nginx.conf
worker_processes  1;
 
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    geo $geo {
        default default;
        192.168.6.189/32        uk;
        192.168.6.8/32          us;
#这里的子网码是 32 是因为,我是单网段测试,如果你有VLAN,你可以是24  例如
#  192.168.0.0/24      tw
    }
    upstream    uk.server {
        server 192.168.6.101;
    }
    upstream    us.server {
        server 192.168.6.102;
    }
    upstream    default.server {
        server 192.168.6.121:8080;
    }
    sendfile        on;
    keepalive_timeout  65;

    server {
        listen       80;
        server_name  192.168.6.121;
        index index.html index.htm;
        root html;

        location / {
               proxy_redirect off;
               proxy_set_header Host $host;
               proxy_set_header X-Real-IP $remote_addr;
               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
               proxy_pass http://$geo.server$request_uri;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
 
    }
 
    server {
        listen       8080;
        server_name  192.168.6.121;
        location / {
            root   html;
            index  index.html index.htm;
        }
    }
}
 
3.测试,在测试机1 上打开浏览器输入
http://192.168.6.121
显示
因为 测试机1 IP地址为 192.168.6.2 按照  nginx 配置,他访问的很明显是 server3  8080 端口!因为 server1 server2 的 index.html 我修改了
 
在 测试机2  上打开浏览器~输入
http://192.168.6.121
显示
 
在 测试机3上打开浏览器~输入
http://192.168.6.121
测试机3 IP为 192.168.6.189
显示:
 
很明显,负载均衡起到了作用~~~
 
 
这样就可以把 三台服务器分别放到不同的IDC 机房。然后在数据同步就可以了~这样做的好处就是省去了在DNS 上做手脚,因为智能DNS 有时候按照来访IP解析的时候会解析对方的DNS地址,把他匹配到一台服务器,如果对方是网通用户,他用的电信DNS,会直接把他匹配到电信的服务器,NGINX,确确实实的根据来访问IP来匹配服务器的,这样只要我们把各地区的IP段收集起来就可以了~~

本文出自 “linuxer” 博客,请务必保留此出处http://deidara.blog.51cto.com/400447/196276