apache负载均衡 健康检查_Nginx负载均衡与健康检查

upstream中使用ip_hash模式时,为什么weight选项会被忽略?因为ip_hash模式使用的负载均衡算法是根据请求ip进行hash,而weight模式使用的wrr算法,所以不可同时使用2、代理模块(proxy)Proxy为Nginx的代理模块,允许负责将用户的HTTP请求转发到后端服务器,同时也可以结合upstream模块,达到负载均衡的目的注:proxy相关功能、指令很多,在此只讲与upstream相关的指令和功能proxy模块常用指令解释:proxy_pass:指定转发到后端服务器的请求,在location中指定,常用URI类型如下TCP套接字:proxy_passhttp://127.0.0.1:8080;Unix套接字:proxy_pass http://unix:/tmp/nginx.sock;Upstream区段:proxy_pass http://nginx_pool;域名:proxy_passhttp://www.a.com;proxy_pass使用域名命名时,为什么不能和server_name相同 ?如上图所以,其数据访问流如下:①        、用户访问www.a.com,server_name指令监听并接受www.a.com请求内容②        、server_name将www.a.com的请求转交给proxy_pass指令处理③        、proxy_pass接到请求后根据相应URI进行处理(此处URI为www.a.com),因为我们此处URI为域名,所以proxy_pass会请求DNS进行解析④        、proxy_pass收到DNS解析结果(www.a.com),去请求server_name由此可见如果proxy_pass的URI命名若和server_name命名相同,则形成一个请求环路。所以在配置proxy_pass的URI时,应避免和本server内的server_name重名二、健康检查Nginx的健康检查主要体现在对后端服务提供健康检查,且功能被集成在upstream模块中,共有两个指令max_fails:定义定义可以发生错误的最大次数fail_timeout:nginx在fail_timeout设定的时间内与后端服务器通信失败的次数超过max_fails设定的次数,则认为这个服务器不在起作用;在接下来的 fail_timeout时间内,nginx不再将请求分发给失效的server。健康检查机制:Nginx在检测到后端服务器故障后,nginx依然会把请求转向该服务器,当nginx发现timeout或者refused后,会把改请求会分发到upstream的其它节点,直到获得正常数据后,nginx才会把数据返回给用户,这也便体现了nginx的异步传输,而lvs/haproxy/apache责无法做到这些(在lvs/haproxy/apache里,每个请求都只有一次机会,假如用户发起一个请求,结果该请求分到的后端服务器刚好挂掉了,那么这个请求就失败了)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值