网站首页 > 技术教程 正文
nginx负载均衡
一、负载均衡的原理
二、如何实现负载均衡
在HTTP上下文中声明一个upstream指令
#scshop只是一个名字的代号,可以随便写
upstream ecshop {
server 192.168.40.135:8081;
server 192.168.40.129:80;
}
在server上下文中声明调用分发的upstream指令
location / {
root html;
#下面这行代码是通过proxy_pass指令将客户端访问我们的请求分发到其它服务器上
#http后面的ecshop应该也upstream后面ecshop一至
proxy_pass http://ecshop;
index index.php index.html index.htm;
}三、负载均衡的算法
nginx收到客户端的请求后,如何将这个请求分发到我们后台服务器,这个过程中负载均衡的算法,nginx负载均衡的算法通常有以下几种:
1.轮询
是指请求按顺序的分发给我们的服务器,默认是轮询的方式。
2.最少连接数
优先将请求分发给目前连接数最少的服务器
upstream ecshop {
least_conn;
server 192.168.40.135:8081 max_fails=3 fail_timeout=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}3.ip哈希
通过ip_hash算法保证同一个连接访问是同一台服务器
upstream ecshop {
ip_hash;
server 192.168.40.135:8081 max_fails=3 fail_timeout=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}4.通用哈希
通过 $request_uri和consistent密钥来计算出我们访问的IP地址
upstream ecshop {
hash $request_uri consistent;
server 192.168.40.135:8081 max_fails=3 fail_timeout=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}5.最少时间
是指处理请求所花费的最小时间来分发,衡量最少时间又有以下三种方式:
--->header:表示处理完成第一个字节的时间
--->last_byte :表示服务器接受到所有内容的时间
--->last_byte inflflight :表示如果是一个不完整的请求,服务器接受到所有内容的时间
upstream ecshop {
least_time header;
server 192.168.40.135:8081 max_fails=3 fail_timeout=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}6.随机
将请求随机的发送到服务器,如果使用two,那应该需要设置两个参数来约束随机
upstream ecshop {
random two least_time=header;
server 192.168.40.135:8081 max_fails=3 fail_timeout=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}四、设置服务器的权重
所谓的权重就是对分发服务器所处理请求的比例进行约束,使用关键weight来实现
upstream ecshop {
server 192.168.40.135:8081 weight=5;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}
上面的设置的含义表示,如果一个7个请求,192.168.40.135:8081这台服务器会处理5个请求,192.168.40.129:80这台服务器处理1个请求,192.168.40.135:8082这台服务器处理1个请求。五、慢启动
慢启动是指服务器晚些时间接受请求,慢启动可以尽量避免服务器被“淹没”。
upstream ecshop {
server 192.168.40.135:8081 weight=5 slow_start=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}
一般如果单台服务器会将慢启与max_failst和fail_timeout两个参数一块使用。六、限制连接数
限制连接数是指可以对某服务器最大连接数进行约束
upstream ecshop {
server 192.168.40.135:8081 max_conns=10;
server 192.168.40.129:80;
server 192.168.40.135:8082;
queue 100 timeout=70;
}
如果连接数超过最大连接数就会进行排队,所以还可以设置一个排队数以及超时时间
queue表示队列长度
timeout表示超时时间
如果在超时时间范围内都没有处理那就会将错误返回给客户端七、健康检查
健康检查是指如果分发服务器连接出错,那么就不应该继续给这台服务器分发请求,如果持续分发请求,就可能导致更的错误,所以会使用max_fails和fail_timeout来约束。
upstream ecshop {
random two least_time=header;
server 192.168.40.135:8081 max_fails=3 fail_timeout=30s;
server 192.168.40.129:80;
server 192.168.40.135:8082;
}
max_fails表示达到这么多次失败后,nginx会将这台服务器标为失效的服务器,如果这个选项设置为0那么表示这台服务器被禁用。
fail_timeout表示这段时间内不接受客户端的请求
猜你喜欢
- 2024-10-10 平台进程监控介绍(系统进程监控软件)
- 2024-10-10 Zabbix监控系统系列之八:监控nginx服务
- 2024-10-10 深度|掌握Nginx监控运维,这一篇足矣!
- 2024-10-10 Nginx 监控(nginx监控工具)
- 2024-10-10 如何轻松监控Nginx?(nginx 监控)
- 2024-09-11 这可能是把Nginx讲解的最透彻的一本新书
- 2024-09-11 nginx动态添加nginx-module-vts监控流量
- 2024-09-11 Docker 容器操作:运行、监控与维护
- 2024-09-11 用groovry做简单的nginx日志实时监控脚本
- 2024-09-11 教你三种方法,用 Python实时监控文件
欢迎 你 发表评论:
- 10-23Excel计算工龄和年份之差_excel算工龄的公式year
- 10-23Excel YEARFRAC函数:时间的"年份比例尺"详解
- 10-23最常用的10个Excel函数,中文解读,动图演示,易学易用
- 10-23EXCEL中如何计算截止到今日(两个时间中)的时间
- 10-2390%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 10-23计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- 10-23Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 10-23怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- 最近发表
-
- Excel计算工龄和年份之差_excel算工龄的公式year
- Excel YEARFRAC函数:时间的"年份比例尺"详解
- 最常用的10个Excel函数,中文解读,动图演示,易学易用
- EXCEL中如何计算截止到今日(两个时间中)的时间
- 90%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- Excel日期函数之DATEDIF函数_excel函数datedif在哪里
- Excel函数-DATEDIF求司龄_exceldatedif函数计算年龄
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)

本文暂时没有评论,来添加一个吧(●'◡'●)