当前位置:首页 > 技术文章 > 正文内容

Nginx后端服务器组的配置

arlanguage4个月前 (01-07)技术文章28


Nginx服务器支持设置一组服务器作为后端服务器,在学习Nginx服务器的反向代理、负载均衡等重要功能时会经常涉及后端服务器。

服务器组的设置包括几个指令,它们是由标准HTTP模块ngx_http_upstream_module进行解析和处理的。

1、upstream指令

该指令是设置后端服务器组的主要指令,其他的指令都在该指令中进行配置。upstream指令类似与之前提到的http块、server块,其语法结构为:

upstream name { ... }

其中,name是给后端服务器组起的组名。花括号中列出后端服务器组中包含的服务器,其中可以使用下面介绍的其他指令。

默认情况下,某个服务器组接收到请求后,按照轮叫调度(Round-Robin,RR)策略顺序选择组内服务器处理请求。如果一个服务器在处理请求的过程中出现错误,请求会被顺次交给组内的下一个服务器进行处理,以此类推,直接返回正常响应。但如果所有的组内服务器都出错,则返回最后一个服务器的处理结果。当然我们可以根据各个服务器处理能力或者资源配置情况的不同,给各个服务器配置不同的权重,让能力强的服务器多处理请求,能力弱的少处理。配置权重的变量包含在server指令中。

2、server指令

该指令用于设置组内的服务器,其语法结构为:

server address [parameters];

address:服务器的地址,可以是包含端口号的IP地址(IP:Port)、域名或者以“unix:”为前缀用于进程间通信的Unix Domain Socket。

parameters:为当前服务器配置多属性,这些属性变量包括以下内容:

weight=number:为组内服务器设置权重,权重值高的服务器被优先用于处理请求。此时组内服务器的选择策略为加权轮叫策略。组内所有服务器的权重默认设置为1,即采用一般轮叫调度原则处理请求。

max_fails=number:设置一个请求失败的次数。在一定时间范围内,当对组内某台服务器请求失败的次数超过该变量设置的值时,认为该服务器无效。默认设置为1。如果设置为0,则不使用上面的办法检查服务器是否有效。

fail_timeout=number:有两个作用,一是设置max_fails指令尝试请求某一组内服务器的时间,即学习max_fails指令时提到的“一定时间范围内”;另一个作用是在检查服务器是否有效时,如果一台服务器被认定是无效的,该变量设置的时间为认为服务器无效的持续时间。在这个时间内不再检查该服务器的状态,并一直认为它是无效的。默认设置为10s。

backup:将某台组内服务器标记为备用服务器,只有当正常的服务器处于无效状态或者繁忙状态时,该服务器才被用来处理客户端请求。

down:将某台组内服务器标记为永久的无效状态,通常与ip_hash指令配合使用。

upstream backend

{

server backend1.example.com weight=5;

server 127.0.0.1:8080 max_fails=3 fail_timeout=30s;

server unix:/tmp/backend3;

}

3、ip_hash指令

该指令用于实现会话保持功能,将某个客户端的多次请求定向到组内同一台服务器上,保证客户端与服务器之间建立稳定的会话。只有当该服务器处于无效状态时,客户端请求才会被下一个服务器接收和处理。其语法结构为:

ip_hash;

ip_hash技术在一些情况下非常有用,能够避免我们关心的服务器组内各服务器之间会话共享的问题。但是ip_hash技术在实际使用过程中也有限制。

首先,ip_hash指令不能与server指令中的weight变量一起使用。其次,由于ip_hash技术主要根据客户端IP地址分配服务器,因此在整个系统中,Nginx服务器应该是处于最前端的服务器,这样才能获取到客户端的IP地址,否则它得到的IP地址将是位于它前面的服务器地址,从而会产生问题,同时要注意,客户端IP地址必须是C类地址。

upstream backend

{

ip_hash;

server myback1.proxy.com;

server myback2.proxy.com;

}

4、keepalive指令

该指令用于控制网络连接保持功能。通过该指令,能够保证Nginx服务器的工作进程为服务器组打开一部分网络连接,并且将数量控制在一定的范围之内。其语法结构为:

keepalive connections;

其中,connections为Nginx服务器的每一个工作进程允许该服务器组保持的空闲网络连接数的上限值。如果超过该值,工作进程将采用最近最少使用的策略关闭网络连接。

5、least_conn指令

该指令用于配置Nginx服务器使用负载均衡策略为网络连接分配服务器组内的服务器。该指令在功能上实现了最少连接负载均衡算法,在选择组内的服务器时,考虑各服务器权重的同时,每次选择的都是当前网络连接最少的那台服务器,如果这样的服务器有多台,就采用加权轮叫原则选择权重最大的服务器。其语法结构为:

least_conn;


更多c/c++ Linux服务器高阶知识、电子书籍、视频等等请后台私信【架构】获取

文末给大家分享一波知识点有C/C++,Linux,golang技术,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等等。


扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/668.html

分享给朋友:

“Nginx后端服务器组的配置” 的相关文章

Nginx总结(六)nginx实现负载均衡

前面讲了如何配置Nginx虚拟主机,大家可以去这里看看nginx系列文章:https://www.cnblogs.com/zhangweizhong/category/1529997.html今天要说的是如何配置nginx和tomcat实现反向代理。需要说明的是:由于本文章是nginx系列文章中的一...

Nginx Lua编程基础

Lua是一门脚本动态语言,并不太适合做复杂业务逻辑的程序开发,但是,在高并发场景下,Nginx Lua编程是解决性能问题的利器。Nginx Lua编程主要的应用场景如下:API网关:实现数据校验前置、请求过滤、API请求聚合、AB测试、灰度发布、降级、监控等功能,著名的开源网关Kong就是基于Ngi...

「每天一道面试题」Nginx 502错误原因和解决方法

Nginx 502错误原因和解决方法不管你是做运维还是做开发,哪怕你是游客,时不时会遇到 502 Bad Gateway 或 504 Gateway Time-out。出现这页面,把服务重启下,再实在不行重启下服务器,问题就解决了,特殊情况请继续阅读。状态码解释502 Bad Gateway:作为网...

nginx出现大量499响应码怎么办?

一、问题现象监控发现Nginx服务日志中出现较多的499状态码,499状态码在Nginx中代表的是客户端在服务端返回之前主动断开了连接,由于客户端设置的超时时间为2s,故到达2s未收到服务端响应客户端主动断开了连接造成了499响应码。二、可能的故障点服务器的问题,例如CPU使用率高,队列堵塞,导致无...

Nginx的安装及配置详解 nginx1.12安装

Nginx是一个强大的免费开源的HTTP服务器和反向代理服务器。在Web开发项目中,nginx常用作为静态文件服务器处理静态文件,并负责将动态请求转发至应用服务器(Django, Flask, etc)。熟悉Nginx的配置对Web开发和运维人员来说至关重要。本文整理了Nginx的配置大全,可以作为...

Nginx 的性能调优: 从入门到精通

Nginx 是一种高效的 Web 服务器和反向代理,广泛应用于互联网中。通过性能调优,Nginx 可以进一步提高其服务质量和性能。本文将从入门到精通,介绍 Nginx 性能调优的方法和技巧。一、什么是 Nginx?Nginx 是一种开源的 Web 服务器和反向代理软件,由 Igor Sysoev 创...