Nginx对后端节点健康检查

严格来说,nginx自带是没有针对负载均衡后端节点的健康检查的,但是可以通过默认自带的ngx_http_proxy_module模块和ngx_http_upstream_module模块中的相关指令来完成当后端节点出现故障时,自动切换到健康节点来提供访问。

ngx_http_proxy_module 模块


里面的proxy_connect_timeout 指令、proxy_read_timeout指令和proxy_next_upstream指令

1、设置与后端服务器建立连接的超时时间。应该注意这个超时一般不可能大于75秒。
语法: proxy_connect_timeout time;
默认值:proxy_connect_timeout 60s;
上下文:http, server, location
2、定义从后端服务器读取响应的超时。此超时是指相邻两次读操作之间的最长时间间隔,而不是整个响应传输完成的最长时间。如果后端服务器在超时时间段内没有传输任何数据,连接将被关闭。
语法: proxy_read_timeout time;
默认值:proxy_read_timeout 60s;
上下文:http, server, location
3、指定在何种情况下一个失败的请求应该被发送到下一台后端服务器:
error           # 和后端服务器建立连接时,或者向后端服务器发送请求时,或者从后端服务器接收响应头时,出现错误
timeout         # 和后端服务器建立连接时,或者向后端服务器发送请求时,或者从后端服务器接收响应头时,出现超时
invalid_header  # 后端服务器返回空响应或者非法响应头
http_500        # 后端服务器返回的响应状态码为500
http_502        # 后端服务器返回的响应状态码为502
http_503        # 后端服务器返回的响应状态码为503
http_504        # 后端服务器返回的响应状态码为504
http_404        # 后端服务器返回的响应状态码为404
off             # 停止将请求发送给下一台后端服务器

语法: proxy_next_upstream error | timeout | invalid_header | http_500 | http_502 | http_503 | http_504 |http_404 | off ...;
默认值:    proxy_next_upstream error timeout;
上下文:    http, server, location

4、proxy内部参数说明

参数解释
proxy_set_header设置由后端服务器获取用户的主机名或者真实IP地址,以及代理者的真实IP地址
client_body_buffer_size指定客户端请求主体缓冲区大小
proxy_connect_timeout表示与后端服务器连接的超时时间,即发起握手等待响应的超时时间
proxy_send_timeout表示后端服务器的数据回传时间,即在规定时间内后端服务器必须传完所有的数据,否则nginx将断开这个连接
proxy_read_timeout设置nginx从代理的后端服务器获取信息的时间,表示连接建立成功后,nginx等待后端服务器的响应时间,其实是nginx已经进入后端的排队之中等候处理的时间
proxy_buffer_size设置缓冲区大小,默认,该缓冲区大小等于指令proxy_buffers设置的大小
proxy_buffers设置缓冲区数量和大小。nginx从代理的后端服务器获取的响应信息,会放到缓冲区
proxy_busy_buffers_size用于设置系统很忙时可以使用的proxy_buffers大小,官方推荐的大小为 proxy_buffers*2
proxy_temp_file_write_size指定proxy缓存临时文件的大小


备注
只有在没有向客户端发送任何数据以前,将请求转给下一台后端服务器才是可行的。也就是说,如果在传输响应到客户端时出现错误或者超时,这类错误是不可能恢复的。

范例如下:

http {
    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_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504 http_404;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_redirect off;
    proxy_connect_timeout 90; ;
    proxy_send_timeout 90; ;
    proxy_read_timeout 90;
    proxy_buffer_size 4k;
    proxy_buffers 4 32k;
    proxy_busy_buffers_size 64k;
    proxy_temp_file_write_size 64k;
}

ngx_http_upstream_module模块

1、server指令

upstream web_server {
    server 192.168.88.133:80;
    server 192.168.88.134:80;
    check interval=3000 rise=2 fall=5 timeout=1000;
}

备注
①interval检测间隔时间,单位为毫秒,rise请求2次正常的话,标记此realserver的状态为up,fall表示请求5次都失败的情况下,标记此realserver的状态为down,timeout为超时时间,单位为毫秒。

②upstream 模块内部参数说明

参数说明
weight权重
max_fails=2最大尝试失败的次数,默认是1,0表示禁止失败尝试。
backup热备配置(RS节点的高可用),当前面激活的RS节点都失败后会自动启动热备RS
fail_timeout=20s失败超时时间,默认是10s
down表示服务器永远不可用,这个参数一致配合ip_hash使用


2、在server段里面可以加入查看real server状态的页面

location /nstatus {
    check_status;
    access_log off;
    #allow SOME.IP.ADDRESS;
    #deny all;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值