Nginx心跳检测

通常我们会使用Nginx的ngx_http_upstream_module模块来配置服务器组,示例如下

upstream springboot {
    server 10.3.73.223:8080 max_fails=2 fail_timeout=30s;
    server 10.3.73.223:8090 max_fails=2 fail_timeout=30s;
}
 
server {
    listen       80;
    server_name  localhost;
 
    location /test {
        proxy_pass http://springboot;
    }
}

在30s内(fail_timeout,默认值为10s),与服务端通讯失败2次(max_fails,默认值为1,设置为0则认为服务端一直可用),则认为服务器不可用

不可用服务器在30s内与服务端通讯成功2次,则认为服务器恢复

特别需要注意的是,何为与服务端通讯失败是由upstream的使用方定义的(ngx_http_proxy_module、proxy_next_upstream、fastcgi_next_upstream和memcached_next_upstream)

以proxy_next_upstream为例:

与服务端建立连接、向服务端发送请求或者解析服务端响应头时,发生异常或超时将被认为是通讯失败

服务端返回的响应为空或不合法将被认为是通讯失败

如果配置了http_500,http_502,http_503,http_504和http_429,服务端返回这些状态码将被认为是通讯失败

服务端返回http_403和http_404永远不会被认为通讯失败

当upstream中的一台服务器响应失败时, Nginx会将请求转发给下一台服务器,直到所有的服务器都发送过该请求,如果此时依然无法获得成功的响应,客户端将收到最后一台服务器返回的响应结果

使用上面的配置进行测试:

package com.sean.test;

import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframe
  • 4
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Nginx心跳包**是一种用于健康检查的机制,它帮助Nginx监测后端服务器的状态**。 Nginx本身并不直接提供心跳检测功能,而是通过其模块`ngx_http_upstream_module`和`ngx_http_proxy_module`中的相关指令来完成对后端节点的健康检查。当后端节点出现故障时,Nginx能够将流量切换到健康的节点上,从而保证服务的可用性。为了增强这一功能,Nginx提供了一个名为`ngx_http_upstream_hc_module`的模块,它允许周期性地对服务器组中的服务器进行健康检查。这需要配置Nginx配置文件中,并设置相应的检查间隔和失败判断条件。 心跳包的基本概念是在客户端和服务器之间定时发送特定的数据包,以确认对方是否在线或运行正常。如果在指定的时间内没有收到对方的响应,那么通常会认为对方已经离线或出现了故障。心跳包通常用于检测TCP连接的异常断开,它是一种简单有效的健康监测手段。 在实际应用中,心跳包的实现可以通过在程序中设置一个定时器,按照预定的时间间隔自动发送预先规定好格式的数据包。如果通信双方已经有频繁的数据交换,那么心跳包的发送可能会与这些数据流合并,以避免额外的网络流量。 综上所述,Nginx心跳包是Nginx用来检测后端服务器健康状态的一种机制,它有助于确保用户请求始终被路由到可用的后端服务器上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值