nginx是一款很强大的http和反向代理服务器。它的功能非常强大。
并不是一开始就需要负载均衡集群,当网络流量不断增长,单个处理单元无法满足负载请求时,网络应用流量将要出现瓶颈时,负载均衡才会起到作用。
负载均衡与反向代理区别:负载均衡是反向代理的其中一个功能。反向代理服务器还可以缓存静态资源。当用户有请求时,直接返回反向代理服务器上的资源给用户,如果反向代理服务器上没有资源就转发给后端负载均衡服务器。
反向代理一般配置:
http {upstream fight { 192.168.3.10:80 weight=1 max_fails=2 fail_timeout=10s; 192.168.3.11:80 weight=1 max_fails=2 fail_timeout=10s;##fight代表负载均衡事物名称,weight代表权值,max_fail代表请求失败次数,fail_timeout代表在经历max_fail错误请求后,超时时间后暂停服务。 } server { listen 80; server_name 192.168.3.9; root /var/www/html; location / { proxy_pass http://fight; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #host代表主机名,以上设置可以显示真实访问ip,以下是各种参数,可有可无 client_max_body_size 10m; #允许客户端请求的最大单文件字节数 client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数 proxy_connect_timeout 300; #nginx跟后端服务器连接超时时间(代理连接超时) proxy_send_timeout 300; #后端服务器数据回传时间(代理发送超时) proxy_read_timeout 300; #连接成功后,后端服务器响应时间(代理接收超时) proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小 proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置 } }}
nginx还支持多组的负载均衡,可以配置多个upstream,来服务于不同的server。
nginx的upstream目前支持多种方式的分配,以下是常用几种。
<1>轮询(默认)
每个请求按照时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能够自动剔除。
<2>weight
指定轮询几率,wight和访问比率成正比,用于后端服务器性能不均的情况下。
<3>ip_hash
每个请求按照访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
nginx反向代理不仅可以为后端多台服务器做负载均衡,还可为后端较慢的服务器提供缓存服务,还可启用高级url策略和管理技术,从而使处于不同web服务器系统的web界面同时处于同一url空间下。