Nginx深入详解之upstream分配方式

一、分配方式
        Nginx的upstream支持5种分配方式,下面将会详细介绍,其中,前三种为Nginx原生支持的分配方式,后两种为第三方支持的分配方式:
1、轮询         
        轮询是upstream的默认分配方式,即每个请求按照时间顺序轮流分配到不同的后端服务器,如果某个后端服务器down掉后,能自动剔除。
        upstream backend {
            server 192.168.1.101:8888;
            server 192.168.1.102:8888;
            server 192.168.1.103:8888;
        }
2、weight        
        轮询的加强版,即可以指定轮询比率,weight和访问几率成正比,主要应用于后端服务器异质的场景下。
        upstream backend {
            server 192.168.1.101 weight=1;
            server 192.168.1.102 weight=2;
            server 192.168.1.103 weight=3;
        }
3、ip_hash        
        每个请求按照访问ip(即Nginx的前置服务器或者客户端IP)的hash结果分配,这样每个访客会固定访问一个后端服务器,可以解决session一致问题。
        upstream backend {
            ip_hash;
            server 192.168.1.101:7777;
            server 192.168.1.102:8888;
            server 192.168.1.103:9999;
        }
4、fair        
        fair顾名思义,公平地按照后端服务器的响应时间(rt)来分配请求,响应时间短即rt小的后端服务器优先分配请求。
        upstream backend {
            server 192.168.1.101;
            server 192.168.1.102;
            server 192.168.1.103;
            fair;
        }
5、url_hash
        与ip_hash类似,但是按照访问url的hash结果来分配请求,使得每个url定向到同一个后端服务器,主要应用于后端服务器为缓存时的场景下。
        upstream backend {
            server 192.168.1.101;
            server 192.168.1.102;
            server 192.168.1.103;
            hash $request_uri;
            hash_method crc32;
        }
        其中,hash_method为使用的hash算法,需要注意的是:此时,server语句中不能加weight等参数。
        关于,如何在负载均衡中使用upstream请参看这里

二、设备状态
        从上面实例不难看出upstream中server指令语法如下:
        server address [parameters]
        关键字server必选。
        address也必选,可以是主机名、域名、ip或unix socket,也可以指定端口号。
        parameters是可选参数,可以是如下参数:
        down:表示当前server已停用
        backup:表示当前server是备用服务器,只有其它非backup后端服务器都挂掉了或者很忙才会分配到请求。
        weight:表示当前server负载权重,权重越大被请求几率越大。默认是1.
        max_fails和fail_timeout一般会关联使用,如果某台server在fail_timeout时间内出现了max_fails次连接失败,那么Nginx会认为其已经挂掉了,从而在fail_timeout时间内不再去请求它,fail_timeout默认是10s,max_fails默认是1,即默认情况是只要发生错误就认为服务器挂掉了,如果将max_fails设置为0,则表示取消这项检查。
        举例说明如下:
        upstream backend {
            server    backend1.example.com    weight=5;
            server    127.0.0.1:8080               max_fails=3 fail_timeout=30s;
            server    unix:/tmp/backend3;           
        }

        如何引用呢? 如下

        location  /router/
                {
                proxy_pass http://backend;
                proxy_set_header Host $host;
                proxy_set_header X-Real_IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

                }

以下可以解决只有一个合法的业务域名的问题

        location /test/router
                {
                proxy_pass http://test.yl.66huyu.cn/router;
                proxy_set_header Host $host;
                proxy_set_header X-Real_IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }

如何做游戏多区多服的https的反向代理设置:

        location /zone {
                proxy_set_header Host $host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "upgrade";
                proxy_read_timeout 86400;
                proxy_pass http://$arg_host:$arg_port;
        }

客户端请求 :wss://www.ooxx.com/zone?host=134.175.33.159&port=8888

nginx自动会把参数加arg_前缀,代理向ttp://$arg_host:$arg_port,则客户端自动就连向了http://134.175.33.151:8888

如何做服务器端重定向?

	location ~*/router/.+ {
		rewrite ^/  /home/index.html redirect;
	}

这样就会把

https://game1.ooxx.com/1621423203685/router/wechat/login.do?pid=ningbo&invitorId=184815&tableId=136615​​​​​​c​c

重定向为

https://game1.ooxx.com/home/index.html?pid=ningbo&invitorId=184815&tableId=136615

https://ooxx.com/download/file?url=http://shanghai.myqcloud.com/official/videos/ssstwitter.com_1706686799043.mp4

通过反向代理配置,来访问腾讯云的COS源下载文件时,发现总是502 Bad Gateway,

反向代理配置如下:

location /download/file {
    set $filename '';
   if ($arg_url ~* "/([^/]+)\.(\w+)$") {
        set $filename "$1.$2";
    }
    proxy_pass $arg_url;
    add_header Content-Type application/octet-stream;
    add_header Content-Disposition "attachment; filename=$filename";
}

后来发现,

如果没有配置resolver或者配置的DNS服务器无法正确解析你设置在proxy_pass指令中的域名,Nginx就可能无法通过域名找到目标服务器的IP地址,从而导致代理失败。当你直接使用IP地址时,Nginx无需进行DNS解析就能直接与后端服务器建立连接,所以代理能够成功。

若你的环境中需要基于域名进行代理,并且默认的DNS解析机制不能满足需求(例如内部服务、特定DNS服务器等),请务必在Nginx配置中添加合适的resolver配置,以确保域名可以被正确解析为有效的IP地址:

resolver 119.29.29.29 valid=300s;

可以放到location,server,或者http层级,

location /download/file {
    set $filename '';
   if ($arg_url ~* "/([^/]+)\.(\w+)$") {
        set $filename "$1.$2";
    }
    proxy_pass $arg_url;
	resolver 119.29.29.29 valid=300s;
    add_header Content-Type application/octet-stream;
    add_header Content-Disposition "attachment; filename=$filename";
}

我们放到location中先

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: Nginxupstream配置用于定义后端服务器的地址及相关配置,可以实现负载均衡、缓存等功能。 具体来说,upstream配置需要在Nginx的配置文件中定义一个upstream块,该块中包含多个server指令,每个server指令对应一个后端服务器。可以为每个server指令指定服务器的IP地址、端口号、权重、健康检查等参数。Nginx会根据这些参数对请求进行负载均衡,将请求转发到后端服务器进行处理。 除了server指令,upstream块还可以包含一些其他指令,如zone指令用于定义一个共享内存区域,用于存储后端服务器的状态信息;keepalive指令用于控制与后端服务器的TCP连接复用等。 需要注意的是,upstream配置需要在Nginx的http块中定义,而不能在server块中定义。同时,在配置upstream时,需要考虑后端服务器的负载情况、网络环境等因素,进行合理的调整,以提高系统的性能和稳定性。 ### 回答2: Nginx是一种高性能、开源的HTTP和反向代理服务器。其中,“UPSTREAM”(上游)是Nginx中有机构成的一部分,在进行反向代理或负载均衡时,它扮演着至关重要的角色。这篇文章将详细介绍如何在Nginx中配置UPSTREAMUPSTREAM是什么? UPSTREAM是指Nginx将需要处理的请求转发至一组上游服务器,例如Web服务器、应用服务器等。这些服务器负责为客户端提供所需的服务。UPSTREAM可以帮助用户实现反向代理和负载均衡。 UPSTREAM的配置 UPSTREAM的配置具体流程如下: 1.编辑Nginx配置文件 在Nginx配置文件中添加UPSTREAM的相关内容。示例如下: ``` upstream backend{ server 10.0.0.1:8080; server 10.0.0.2:8080; } ``` 此处定义了一个名为backend的UPSTREAM,其中有两个服务器。这两个服务器需要提供相同服务的内容。Nginx会将客户端请求转发至这两个服务器的其中一个。 2.配置反向代理 在Nginx配置文件中添加反向代理配置。例如: ``` location / { proxy_pass http://backend; } ``` 此处定义了一个location(位置)块,将会匹配所有请求。Nginx会将这些请求反向代理至backend UPSTREAM中的某个服务器。如果有多个UPSTREAMNginx会根据负载均衡算法选择服务器。 3.配置负载均衡算法 Nginx支持多种负载均衡算法,如轮询、IP哈希等。默认情况下,Nginx使用轮询算法。例如: ``` upstream backend { ip_hash; server 10.0.0.1:8080; server 10.0.0.2:8080; } ``` 上面的配置中,Nginx使用IP哈希算法,即根据客户端的IP地址来确定要转发至哪个上游服务器。 4.启动Nginx 配置完成后,启动Nginx以使配置生效。在Linux系统中,使用如下命令: ``` sudo systemctl restart nginx ``` UPSTREAM的优势 使用UPSTREAM有许多优势: 1.实现高可用性 UPSTREAM能够实现多台服务器的负载均衡,避免单点故障,提高系统的可用性。 2.实现更好的性能 使用UPSTREAM能够将请求转发至最近的服务器,从而提高系统响应速度。 3.实现更好的安全性 UPSTREAM能够分发请求至多台服务器,从而减轻单个服务器的负担,降低被攻击的风险。 总结 UPSTREAMNginx的核心模块之一,在反向代理和负载均衡中扮演着至关重要的角色。UPSTREAM配置简单、易用,能够提高系统的可用性、性能和安全性。 ### 回答3: Nginxupstream是一个用于反向代理的模块,允许我们将客户端请求转发给多个服务器。可以用于负载均衡和容错,确保在某个服务器宕机或出现故障时能够自动切换到另一个服务器upstream配置可以定义一组后端服务器,并使用不同的负载均衡算法。以下是nginx upstream配置的详细解释: 1. 定义upstreamupstream块是nginx配置文件中的一个块,用于定义后端服务器的配置。upstream块的语法如下: upstream backend { server 192.168.1.100; server 192.168.1.101; } 在这个块中,我们指定了名为backend的upstream组,同时定义了两个服务器的IP地址。在实际使用中,我们可以在server关键字后跟主机名称或IP地址,然后在每个服务器的下一行添加可选端口号。 2. 配置负载均衡算法 在upstream块中,可以选择不同的负载均衡算法。其中最常使用的算法是轮询算法(默认算法),它将请求轮流分配给不同的后端服务器。还有其他算法可供选择,如随机、权重、IP hash等。以下是一个应用随机算法的例子: upstream backend { server 192.168.1.100; server 192.168.1.101; random; } 3. 配置代理协议 upstream块中,我们也可以指定代理协议。为了提高安全性和性能,我们可以在后端服务中使用HTTPS协议,同时配置Nginx充当HTTPS代理。这需要我们在upstream块中指定两个server,一个是HTTP的服务器,另一个是HTTPS的服务器。以下是一些示例代码: # 用于HTTP协议的upstream upstream backend { server 192.168.1.100; } # 用于HTTPS协议的upstream upstream backend { server 192.168.1.100:80; server 192.168.1.100:443 backup; } 在这个示例中,第一个server是HTTP服务器,第二个server是HTTPS服务器,用于负载均衡。backup关键字用于指定后备服务器。 4. 使用DNS解析 在上面的例子中,我们使用了硬编码的IP地址。但是,当使用DNS解析时,可以使我们更灵活地管理服务器。可以使用resolver指令来指定DNS服务器的IP地址,使用域名而不是IP地址来定义后端服务器。以下是一个dns解析的例子: resolver 8.8.8.8; upstream backend { server api.example.com; } 在这个例子中,我们使用Google DNS(IP地址是8.8.8.8)解析名为api.example.com的域名,而不需要写入硬编码的IP地址。 总结:upstream配置是Nginx反向代理的核心组件,可为后端服务器提供容错和负载均衡。通过nginxupstream配置,我们可以轻松地定义一组后端服务器,并选择不同的负载平衡算法。我们还可以使用代理协议和DNS解析来选择最佳的后端服务器,并提高服务的性能和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值