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

两台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(第三方)


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值