nginx负载均衡

时间:2022-05-14
本文章向大家介绍nginx负载均衡,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

一、nginx负载均衡:

1.1 负载均衡原理:

多台服务器绑定一个域名,当A用户访问WEB服务器的时候,可能访问的是A服务器,当B用户访问WEB服务器的时候可能是A服务器也可能是B服务器,但是一旦A服务器挂掉后,Nginx负载均衡会自动的把所有的访问者全部指向另外一个可以正常工作的WEB server.

1.2 配置:

[[email protected]03 ~]# vim /usr/local/nginx/conf/vhost/load.conf
upstream qq_com
{
    ip_hash;
    server 61.135.157.156:80;
    server 125.39.240.113:80;
}
server
{
    listen 80;
    server_name www.qq.com;
    location /
    {
        proxy_pass      http://qq_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;
    }
}

ip_hash;让同一个用户保持在同一个WEB服务器上

upstream qq_com:定义一个名称;

upstream下面可以定义多个server:port

server_name www.qq.com;定义域名

proxy_pass http://qq_com;代理的名字,就是如上定义的名字。

如上做测试,抓到了qq的server提供地址; 使用此命令(域名解析):

[[email protected] ~]# dig www.qq.com

如果没有此命令:

yum install -y bind-utils

1.3 测试:

[[email protected] ~]# curl -x127.0.0.1:80 www.qq.com
this is a test website www.haha.com

测试+重载 (-t && -s reload) 再次访问就出现了qq页面的源码!

nginx的一个缺陷: 不支持https 也就是说只支持80端口。