Nginx的5种负载均衡配置

Nginx在web应用的部署中,作为一种轻量级的负载均衡服务器,起到很强大的作用,其中的常见5种负载均衡的模式也是我们最常用的,下面给大家介绍一下相关的配置。

Nginx负载的5种策略设置方法:

  1. 轮询(默认)
  2. 指定权重
  3. IP绑定 ip_hash
  4. fair
  5. url_hash

1、轮询(默认)

每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
轮询:nginx默认就是轮询其权重都默认为1,服务器处理请求的顺序:ABABABABAB… 

#自定义服务名
upstream tomcat_server{
   	server 127.0.0.1:1234;
   	server 127.0.0.1:8769;
   }
server {
       listen       80;
       server_name  localhost;
   	location / {
   		proxy_pass http://tomcat_server;
   		proxy_set_header Host $host;  #配置端口,否则可能访问失败
       }

2、指定权重

指定轮询几率,weight权重大小和访问比率成正比,用于后端服务器性能不均的情况。 
加权轮询:跟据配置的权重的大小而分发给不同服务器不同数量的请求。如不设置,则默认1。下面服务器的请求顺序为:ABBABBABBABBABB…

#自定义服务名
upstream tomcat_server{
   	server 127.0.0.1:1234 weight=1;
   	server 127.0.0.1:8769 weight=2;
   }
server {
       listen       80;
       server_name  localhost;
   	location / {
   		proxy_pass http://tomcat_server;
   		proxy_set_header Host $host;  #配置端口,否则可能访问失败
       }

3、ip_hash

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

#自定义服务名
upstream tomcat_server{
		ip_hash;
   	server 127.0.0.1:1234;
   	server 127.0.0.1:8769;
   }
server {
       listen       80;
       server_name  localhost;
   	location / {
   		proxy_pass http://tomcat_server;
   		proxy_set_header Host $host;  #配置端口,否则可能访问失败
       }

4、fair

按后端服务器的响应时间来分配请求,响应时间短的优先分配。

#自定义服务名
    upstream backserver { 
        server server1; 
        server server2; 
        fair; 
    } 
server {
       listen       80;
       server_name  localhost;
   	location / {
   		proxy_pass http://tomcat_server;
   		proxy_set_header Host $host;  #配置端口,否则可能访问失败
       }

5、url_hash

按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。 

   #自定义服务名
     upstream backserver { 
        server squid1:3128; 
        server squid2:3128; 
        hash $request_uri; 
        hash_method crc32; 
    }
server {
       listen       80;
       server_name  localhost;
   	location / {
   		proxy_pass http://tomcat_server;
   		proxy_set_header Host $host;  #配置端口,否则可能访问失败
       }

你可能感兴趣的:(负载均衡,服务器,nginx,java,运维)