先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可以解释N台服务器平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。那么负载均衡的前提就是要有多台服务器才能实现,也就是两台以上即可。

测试环境
由于没有服务器,所以本次测试直接host指定域名,然后在VMware里安装了三台CentOS。


linux vip负载均衡_IP

测试域名  :test.com

A服务器IP :192.168.131.185 (主)

B服务器IP :192.168.131.182

C服务器IP :192.168.131.183


linux vip负载均衡_linux vip负载均衡_02

部署思路
A服务器做为主服务器,域名直接解析到A服务器(192.168.131.185)上,由A服务器负载均衡到B服务器(192.168.131.182)与C服务器(192.168.131.183)上。


域名解析

由于不是真实环境,域名就随便使用一个test.com用作测试,所以test.com的解析只能在hosts文件设置。

打开:C:\Windows\System32\drivers\etc\hosts

在末尾添加

192.168.131.185

A服务器nginx.conf设置
打开nginx.conf,文件位置在nginx安装目录的conf目录下。

在http段加入以下代码

upstream test.com { 
      server  192.168.131.182:80; 
      server  192.168.131.183:80; 
} 

server{ 
    listen 80; 
    server_name test.com; 
    location / { 
        proxy_pass         http://test.com; 
        proxy_set_header   Host             $host; 
        proxy_set_header   X-Real-IP        $remote_addr; 
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for; 
    } 
}


保存重启nginx


nginx中的upstream支持下面几种方式:轮询(默认,按照时间顺序对所有服务器一个一个的访问,如果有服务器宕机,会自动剔除)、weight(服务器的方位几率和weight成正比,这个可以在服务器配置不均的时候进行配置)、ip_hash(对每个请求的ip进行hash计算,并按照一定的规则分配对应的服务器)、fair(按照每台服务器的响应时间(rt)来分配请求,rt晓得优先分配)、url_hash(按照访问url的hash值来分配请求),我这里使用了默认的轮训方式。


B、C服务器nginx.conf设置
打开nginx.confi,在http段加入以下代码

server{ 
    listen 80; 
    server_name test.com; 
    index index.html; 
    root /data0/htdocs/www; 
}




保存重启nginx

测试
当访问test.com的时候,为了区分是转向哪台服务器处理我分别在B、C服务器下写一个不同内容的index.html文件,以作区分。

192.168.131.182)分配到B服务器(192.168.131.183)与C服务器(192.168.5.126)上,实现了负载均衡效果。

B服务器处理页面

 

linux vip负载均衡_nginx_03

C服务器处理页面



linux vip负载均衡_IP_04


ok,成功配置!