您的位置:首页 > 理论基础 > 计算机网络

nginx反向代理实现http负载均衡

2014-06-16 14:49 375 查看
两台centos服务器:

172.16.8.100--nginx,apache

172.16.8.102--apache

nginx作前端反向代理,并且实现后面web服务器的负载均衡(nginx和apache在同一服务器上)

172.16.8.100的nginx相关配置:

1.安装并配置nginx

yum -y install nginx pcre openssl openssl-devel

2.配置nginx反向代理及负载均衡

cd /etc/nginx/conf.d(所有的配置文件都在conf .d中重新编辑)

(1)vim balance.conf

server {

listen 80;

server_name 172.16.8.102;

location / {

proxy_pass http://balance;
}

}

(2)vim balance-http.conf

upstream balance{

server 127.0.0.1:81;

server 172.16.8.100:81;

}

172.16.8.100 nginx配置完成,反向代理本机的127.0.0.1:81和172.16.8.100:81,并且轮询访问,达到负载均衡的效果。

检测nginx配置文件并启动

nginx -t

nginx

172.16.8.100 和172.16.8.102的apache配置:

在两台服务上建立apache基于端口的虚拟机(两台服务器同样配置,这里只以一台为例)

cd /etc/httpd/conf.d

vi vhost.conf

Listen 81

<VirtualHost 172.16.8.100:81>

DocumentRoot /var/www/html

ServerName test

</VirtualHost>

在两台服务器的/var/www/html下建立index文件

echo "hello,172.16.8.100" >index.html

echo "hello,172.16.8.102" >index.html

启动apache

service httpd start

下面来测试下效果:



再次刷新页面就出现“hello,172.168.8.102”,两个页面会交替出现.

ps:采用轮询方式,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

还有其他方式:

weight :指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

ip_hash :每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

fair(第三方):按后端服务器的响应时间来分配请求,响应时间短的优先分配。

url_hash(第三方)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: