先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可以解释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
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服务器处理页面
C服务器处理页面
ok,成功配置!