您的位置:首页 > 运维架构 > Nginx

centos下nginx的负载均衡搭建(图文详解)

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

测试环境

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



测试域名  :test.com

A服务器IP :192.168.131.185 (主)

B服务器IP :192.168.131.182

C服务器IP :192.168.131.183



部署思路

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    test.com

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文件,以作区分。

打开浏览器访问test.com结果,刷新会发现所有的请求均分别被主服务器(192.168.131.182)分配到B服务器(192.168.131.183)与C服务器(192.168.5.126)上,实现了负载均衡效果。

B服务器处理页面

 


C服务器处理页面



ok,成功配置!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: