IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> nginx upstream 的路由策略配置 -> 正文阅读

[系统运维]nginx upstream 的路由策略配置

nginx作反向代理时,提供了多种路由策略来决定请求该路由到哪一个后端节点。有轮询,最少连接,ip_hash,hash,sticky等。

1.weighted round-robin balancing(基于权重的轮询策略)

默认情况下nginx采用的轮询策略。

upstream backend {
    server backend1.example.com weight=3;
    server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081
}

如上面3个后端服务权重占比为 3:1:1,意味着每5个请求,3个分给第一个,其他2个server 各一个

2. least_conn(最少连接数)

将请求转发给连接数最少的后端服务

upstream backend {
    least_conn;
    server backend1.example.com ;
    server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081
}

3. ip_hash(基于客户端ip 进行hash)

根据客户端ip进行hash计算得到对应的后端节点,将请求路由至该节点。
但是如果有多级nginx代理,或者其他特殊的网络拓扑结构,有可能造成资源利用不重复,请求都路由到单个节点的情况。可以考虑hash路由

upstream backend {
    ip_hash;
    server backend1.example.com ;
    server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081
}

4.hash (基于某个变量或者文本 进行hash算法 )

基于某个变量或者文本 进行hash算法 选择对应后端节点。可添加consistent,一致性hash参数,避免新加或移除节点时,hash大面积失效
在这里插入图片描述
如下,基于proxy_add_x_forwarded_for变量,进行hash。在存在多级代理的情况下,nginx为了获取客户端真实ip,通常会设置一个 X_FORWARD_FOR的请求头参数,它的值由多个ip以逗号分割组成,第一个为客户端ip。如果存在多个代理,后续的为nginx代理ip。
proxy_add_x_forwarded_for 表示的意思是,$proxy_add_x_forwarded_for变量包含客户端请求头中的"X-Forwarded-For",与$remote_addr用逗号分开,如果没有"X-Forwarded-For" 请求头,则$proxy_add_x_forwarded_for等于$remote_addr。$remote_addr变量的值是客户端的IP。
在这里插入图片描述

5.session sticky (基于cookie的session 粘黏 )

在upstream 中配置一个cookie属性,对于每一个路由至该upstream的请求,nginx会检查cookie有没有携带用于session粘黏的cookie,如果有则会根据cookie值,选择对应的server将请求,路由至该节点。如果没有对应的cookie,则会给它绑定一个server,将对应的cookie写入客户端。该特性属于nginx商业化特性。需要付费。不过网上有其他人写的类似功能的插件,可以参考:
https://blog.csdn.net/woshiji594167/article/details/85338045
在这里插入图片描述

6.总结

nginx虽然提供了多种路由策略,但是对于软件服务架构偏向于微服务化的今天,默认轮训策略才是合适的。尽量减少系统的有状态性,才能使系统更加健壮,可用性更高。

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 12:01:58  更:2022-05-05 12:04:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 18:35:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码