nginx负均衡中RR和ip_hash策略分析.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
nginx负载均衡中RR和ip_hash策略分析 nginx的upstream目前支持负载均衡方式的分配 1、RR(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。 例如: upstream tomcats { server 07:88 max_fails=3 fail_timeout=3s weight=9; server 32:80 max_fails=3 fail_timeout=3s weight=9; } 2、ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。 例如: upstream tomcats { ip_hash; server 07:88; server 32:80; } 3、fair(第三方) 按后端服务器的响应时间来分配请求,响应时间短的优先分配。 4、url_hash(第三方) 按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。 下面,我们针对RR和ip_hash的负载均衡策略进行分析。因为每一种负载均衡策略都是在upstream的框架中使用,upstream控制总的工作流程,负载均衡策略仅仅提供选择或释放server的函数,所以,我们在分析RR时结合upstream(ngx_http_upstream.c)。 ip_hash大部分内容与RR一致,只是重新实现RR中的ngx_http_upstream_get_peer函数。 RR策略 RR机制分为三个部分:初始化upstream,获取一个可用的后台服务器和释放后台服务器。 以下分析以此配置为例: upstream backend { server A max_fails=3 fail_timeout=4s weight=9; server B max_fails=3 fail_timeout=4s weight=9; server C max_fails=3 fail_timeout=4s weight=9; server D backup; Server E backup; } 2.1 初始化upstream 对于例子中的upstream backend来说, 首先初始化各个server, 除了设置IP和端口号外,还要设置如下置weight,current_weight,max_fails和fail_timeout。其中max_fails和fail_timeout 这两个参数是组合使用的,表示server 如果失败次数达到max_fails 次,并保持fail_timeout秒之内该服务器不能被访问。 对于serverA来说,设置如下 serverA.weight =9; serverA.current_weight = 9; //初始值等于配置文件中的weight. serverA.max_fails = 3; serverA.fail_timeout = 4; 接着,创建两个server类型(在下文介绍中,server类型等同于peer类型,都是用来指明存储upstream中一个server的信息)的数组,peers和backup,分别存储正常的轮循server和备用server. 并且,按照数组中各个server的weight值的大小,由高到底排序。 本例中,在数组peers中存储serverA、serverB和 serverC, 并记录server的总个数peers-number=3; 在数组backup中存储serverD和 serverE, 并记录server的总个数backup-number=2; 最后,设置upstream中各个变量的值。 rrp 表示当前要轮循的server数组,初始设置为Upstream-rrp = peers. tries 表示尝试的次数,当尝试一个server失败后,tries的值就会减一。初始设置为peers的总个数。 Next 表示当peers数组中server都失败,不能提供服务了,通过upstream-next,切换到back数组中选择server. 2.2 具体的RR策略 2.2.1 ) 选择最初要轮循的server, 把它给rrp-current变量,跳转到2.2.2 当一个客户端请求到达nginx后,nginx就会在upstream的peers 数组中挑选一个current_weight最大的se

文档评论(0)

mv2323 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档