博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Nginx学习系列四默认负载均衡轮询及Ip_hash等常用指令介绍
阅读量:5822 次
发布时间:2019-06-18

本文共 708 字,大约阅读时间需要 2 分钟。

一、简介

Upstream模块是Nginx中一个核心模块,当客户端访问Nginx服务器的时候,Nginx会从服务器列表中选取压力小的服务器,然后分配给客户端进行访问.这个过程,Nginx通过轮询算法轮询所有的服务器,找到合适的分配给客户端.而这个过程是通过Upstream模块来实现.

所以,可以将Upstream模块理解为实现轮询算法的负载均衡.

 

二、常用指令

1、ip_hash指令

(1)、简介

在负载均衡系统中,如果客户端已经在某台服务器中登陆,如果我们在访问系统,Nginx会给客户端重新分配一台服务器,这台服务器很有可能不是原先的那台服务器,这显然是不妥的,因为这样就意味着客户端又要重新登陆一次系统.所以需要通过ip_hash指令来解决这个问题.

ip_hash指令的原理:Nginx通过哈希算法(键值对)给每个客户端指定一个对应的服务器,当一个用户已经在一台服务器上登陆,当它再次访问Nginx服务器时,Nginx会从哈希集合中拿到用户上次登陆的那个服务器,然后跳转到服务器.

 

(2)、实现方式

很简单,修改配置文件如下:

i、定位到配置文件

ii、修改配置文件

按esc 输入:wq! 按回车键推出,并重启Nginx服务器

 

 

iii、查看效果

从原先的分别跳到阿里云服务器和百度服务器变成如果跳转到阿里云,如果之后访问则一直跳转到阿里云.

 

2、server指令

(1)、服务器权重weight指令

默认的服务器列表weight权重都为1,当指定weight权重为2时,那么那台服务器,将会承担(2/所有服务器的weight权重和)的压力

注:如果指定了ip_hash的规则,则权重失效.两个规则互斥.

 

转载地址:http://tibdx.baihongyu.com/

你可能感兴趣的文章
关于Android四大组件的学习总结
查看>>
java只能的round,ceil,floor方法的使用
查看>>
由于无法创建应用程序域,因此未能执行请求。错误: 0x80070002 系统找不到指定的文件...
查看>>
新开的博客,为自己祝贺一下
查看>>
【CQOI2011】放棋子
查看>>
采用JXL包进行EXCEL数据写入操作
查看>>
一周总结
查看>>
将txt文件转化为json进行操作
查看>>
线性表4 - 数据结构和算法09
查看>>
C语言数据类型char
查看>>
Online Patching--EBS R12.2最大的改进
查看>>
Binary Search Tree Iterator leetcode
查看>>
uva-317-找规律
查看>>
Event事件的兼容性(转)
查看>>
我的2014-相对奢侈的生活
查看>>
zoj 2412 dfs 求连通分量的个数
查看>>
Java设计模式
查看>>
一文读懂 AOP | 你想要的最全面 AOP 方法探讨
查看>>
Spring Cloud 微服务分布式链路跟踪 Sleuth 与 Zipkin
查看>>
ORM数据库框架 SQLite 常用数据库框架比较 MD
查看>>