Nginx 负债均衡的几种方式
Nginx 负载均衡 大约 2056 字轮询
http {
upstream loadbalanceone{
server 127.0.0.1:9000;
server 127.0.0.1:10000;
}
server {
listen 8000;
location / {
proxy_pass http://loadbalanceone/;
}
}
}
权重
http {
upstream loadbalancetwo{
server 127.0.0.1:9000 weight=1;
server 127.0.0.1:10000 weight=2;
}
server {
listen 8000;
location / {
proxy_pass http://loadbalancetwo/;
}
}
}
ip_hash
根据IP
的哈希值来转发。
ip_hash
可以和weight
共用,当hash
冲突时可以在几台机器间按权重再分配。
ip_hash
不支持backup
指令。
http {
upstream loadbalancethree{
ip_hash;
server 127.0.0.1:9000 weight=1;
server 127.0.0.1:10000 weight=2;
}
server {
listen 8000;
location / {
proxy_pass http://loadbalancethree/;
}
}
}
least_conn
根据连接数来转发,转发至最少连接的那台服务器。
http {
upstream loadbalancefour{
least_conn;
server 127.0.0.1:9000 weight=1;
server 127.0.0.1:10000 weight=2;
}
server {
listen 8000;
location / {
proxy_pass http://loadbalancefour/;
}
}
}
url_hash
http {
upstream loadbalancefive{
hash $request_uri;
server 127.0.0.1:9000 weight=1;
server 127.0.0.1:10000 weight=2;
}
server {
listen 8000;
location / {
proxy_pass http://loadbalancefive/;
}
}
}
其他相关
down
、backup
、max_fails
、fail_timeout
等指令。
down
:表示当前服务不参与负载均衡。backup
:表示其他非backup
服务都down
或繁忙时,请求该服务,这个服务压力最小。max_fails
:允许请求失败的最大次数,默认为1
,当超过max_fails
将不再调度到该服务。fail_timeout
:超过max_fails
后,暂停调度到该服务的时间。
http {
upstream loadbalancesix{
server 127.0.0.1:9000 down;
server 127.0.0.1:10000 backup;
server 127.0.0.1:11000 max_fails=1 fail_timeout=60s;
}
server {
listen 8000;
location / {
proxy_pass http://loadbalancesix/;
proxy_connect_timeout 3s;
}
}
}
注意
ip_hash
不支持backup
指令。
nginx: [emerg] balancing method does not support parameter "backup" in ./conf/nginx.conf:61
阅读 753 · 发布于 2021-05-13
————        END        ————
Give me a Star, Thanks:)
https://github.com/fendoudebb扫描下方二维码关注公众号和小程序↓↓↓

昵称:
随便看看
换一批
-
PostgreSQL增删改使用 returning 获取记录相关属性阅读 1450
-
Golang JSON 的序列化和反序列化阅读 2140
-
Linux 使用 dstat 性能监测阅读 1270
-
软考-系统架构设计师:处理流程设计阅读 1351
-
Android Gradle 去除重复依赖阅读 2464
-
GoLand 提示 Receiver has generic name阅读 940
-
Java 并发编程之 ConcurrentHashMap 1.7 源码分析阅读 372
-
算法:买卖股票的最佳时机阅读 673
-
Nginx upstream timed out 10060阅读 2299
-
Arthas 使用 stack 查找指定方法是被谁调用的阅读 1161