nginx-灰度发布策略(split_clients)

一. 简述:

   基于客户端的灰度发布(也称为蓝绿部署或金丝雀发布)是一种逐步将新版本的服务或应用暴露给部分用户,以确保在出现问题时可以快速回滚并最小化影响的技术。对于 Nginx,可以通过配置和使用不同的模块来实现基于客户端的灰度发布策略。

二. 关于split_clients模块:

split_clients 模块允许您根据客户端的哈希值(如 IP 地址或其他标识符)将流量分配到不同的后端服务器。这对于进行百分比控制的灰度发布非常有用。

 测试环境:

  3个web服务(nginx):10.2.2.250:8080-------------->用于控制用户请求地址(灰度/线上环境)10.2.2.250:8081---------------> 灰度环境10.2.2.250:8082---------------> 线上环境灰度环境部署:请求地址:  http:10.2.2.250:8081/index.html内容:     one------> 8081线上环境部署(nginx安装过程略):请求地址:  http: 10.2.2.250:8082/index.html内容:  two-----------> 8082

8080,配置片段:

http {.....................geo $remote_addrs {#default "106.38.84.18";default "114.18.54.8";}split_clients "${remote_addrs}" $request_type {20% "one";* "two";}upstream test_one {server 127.0.0.1:8081 max_fails=1 fail_timeout=60;}upstream test_two {server localhost:8082 max_fails=1 fail_timeout=60;}server {listen       8080;server_name  localhost;................................if ($request_type = "one") {set $group test_one;}if ($request_type = "two") {set $group test_two;}location / {#root   html;#index index${request_type}.html;proxy_pass http://$group;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;index  index.html index.htm;}
.....}

测试: 

根据定义不同的$remote_addrs值,会进行hash ,分配到不同的分组。
优缺点:

优点:   部署快(nginx默认已集成模块),配置简单,不需要其他部门同事配合,不需要考虑自定义分流工具的风险。

缺点:   从绝对上来说没法具体通过用户请求量的百分比做分流(比如某一个ip段[如10.0.0.x]的请求为主要请求量,ip的hash结果均在一个范围内,这种情况下,有可能都会分流到一个环境上[灰度或线上])。


 

 ----------------------------------------------------------------------------------------------

深耕运维行业多年,擅长linux、容器云原生、运维自动化等方面。
承接各类运维环境部署、方案设计/实施、服务代运维工作,欢迎沟通交流 !

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/66325.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Meta 发布 Llama 3.3:一个性能和效率均有所提升的多语言模型

Meta 发布 Llama 3.3:一个性能和效率均有所提升的多语言模型 Meta 发布了 Llama 3.3,这是一款多语言大语言模型,旨在支持研究和行业中的一系列人工智能应用。该模型具有 128k 个 token 上下文窗口,并对架构进行了改进以提高效率,在推理、编码和多语言任务的基准测试中表现…

【NLP自然语言处理】Transformer模型的几大核心优势与应用前景

目录 🍔 Transformer的并行计算 🍔 Transformer架构的并行化过程 2.1 Transformer架构中Encoder的并行化 2.2 Transformer架构中Decoder的并行化 🍔 Transformer的特征抽取能力 🍔 为什么说Transformer可以代替seq2seq? 4…

Maven中管理SNAPSHOT版本含义及作用

在开发过程中突然产生了一个疑问:IDEA中 maven deploy的依赖包的版本号,比如 1.0.0-SNAPSHOT是在哪配置的?在远程仓库中的版本和这个有关系吗 ? 在 Maven 中,-SNAPSHOT 后缀是用于标识项目版本为快照(Snapshot&#xf…

数据结构与算法之排序

9.1 排序的概念 1. 排序的定义 定义:排序是将表中的记录按关键字递增(或递减)有序排列的过程。说明:数据中可以存在相同关键字的记录。本章主要考虑递增排序。扩展:排序是数据处理中的基本操作之一,广泛应用…

《C++11》各种初始化方式的详细列举与对比

在 C 中,初始化对象的方式多种多样。随着 C 标准的演进,特别是 C11 的引入,初始化方式得到了显著的扩展和改进。本文将详细列举 C 中的各种初始化方式,并对它们进行对比,帮助开发者更好地理解和应用这些特性。 1. C98…

算法:两个升序单链表的合并

将两个按值排序的带头结点的单链表La和Lb排列成一个升序的 单链表,并返回一个新的单链表的表头指针 (两个升序合并成升序,用尾插法) LinkList Merge_LinkList(LNode* La, LNode* Lb) {//准备工作LNode* Lc;//新链表的头结点LNode…

基于 Python Django 的西西家居全屋定制系统(源码+部署+文档)

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

25考研|重邮软件工程复试攻略!

与计算机一样,重邮复试不合格也很有可能被淘汰!快快认真准备起来! 一、复试内容 1、笔试:分值100 2、综合面试:满分100 主要考核考生的综合素质和业务能力,由各招生学院具体组织实施,综合面试…

如何制作重识别数据集及如何解决all query identities do not appear in gallery的问题

如何制作重识别数据集 数据集制作链接 注意点: 按照上述方式制作完成数据集之后,分别建立3个文件夹,分别为train,test,query, 值得注意的是,query文件里的相机编号要进行修改,修改…

链地址法(哈希桶)

链地址法(哈希桶) 解决冲突的思路 开放定址法中所有的元素都放到哈希表⾥,链地址法中所有的数据不再直接存储在哈希表中,哈希表 中存储⼀个指针,没有数据映射这个位置时,这个指针为空,有多个数…

【C语言】可移植性陷阱与缺陷(七): 除法运算时发生的截断

在C语言编程中,除法运算可能会引发一些与可移植性相关的问题,特别是当涉及到整数除法时发生的截断(truncation)。不同平台对于整数除法的行为和处理方式可能会有所不同,这可能导致代码在不同编译器或硬件平台上的行为不…

2. 模型和算法

1. 模型(Model) 模型指的是通过机器学习或其他方法从数据中提取出的一个数学结构或表示,它可以用于做出预测、分类、回归或其他决策任务。模型是机器学习的核心,它在一定程度上是数据的“抽象化”,用于表达输入与输出…

C++ 原子变量

C 原子变量 文章目录 C 原子变量1. 原子变量是什么?2. 原子操作的特点3. 原子变量的作用1. 多线程安全的共享数据访问2. 替代锁机制3. 实现低级同步算法 4. 原子变量的常见操作5. 内存顺序(Memory Ordering)内存顺序控制在原子变量中的作用如…

前后端分离架构设计与实现:构建现代Web应用的基石

前后端分离架构设计与实现:构建现代Web应用的基石 引言 随着互联网技术的发展,Web应用变得越来越复杂和多样化。传统的单体式架构难以满足快速迭代、团队协作以及性能优化的需求。前后端分离架构应运而生,它不仅提高了开发效率,…

了解RabbitMQ的工作原理

RabbitMQ是一个开源的消息代理系统,实现了高级消息队列协议(AMQP)。在现代分布式系统中,特别是在微服务架构中,RabbitMQ有广泛的应用。本文将详细介绍RabbitMQ的工作原理,并通过实践案例帮助读者理解和应用…

Excel中公式和函数的区别

Excel中公式和函数的区别 概念讲解例子公式函数 详细介绍函数面板最后再次进行演示操作文档 概念讲解 公式是用户自己编写的表达式,而函数是由Excel预定义的操作。公式可以包含各种数学运算符和逻辑表达式,函数则是执行特定任务的工具。公式可以引用其他…

分布式搜索引擎之elasticsearch基本使用3

分布式搜索引擎之elasticsearch基本使用3 1.部署单点es 1.1.创建网络 因为我们还需要部署kibana容器,因此需要让es和kibana容器互联。这里先创建一个网络: docker network create es-net1.2.加载镜像 这里我们采用elasticsearch的7.12.1版本的镜像&…

【FlutterDart】 拖动改变 widget 的窗口尺寸大小GestureDetector~简单实现(10 /100)

上效果 预期的是通过拖动一条边界线改变窗口大小,类似vscode里拖动效果。这个是简单的拖动实现 上代码: import package:flutter/material.dart;class MyDraggableViewDemo extends StatelessWidget {const MyDraggableViewDemo({super.key});override…

使用Dinky快速提交Flink operator任务

官网地址:K8s集成 | Dinky 1.目前使用版本 Dinky1.2.0、Flink1.18.1、Flink operator0.10.0 2.制作镜像 2.1创建DockerFile ARG FLINK_VERSION1.18.1 FROM flink:${FLINK_VERSION}-scala_2.12 RUN mkdir -p /opt/flink/usrlib COPY commons-cli-1.3.1.jar …

查找路由器的管理后台ip【通用找IP】

需求: 刚刚搞了个【小米】路由器,我想进路由的管理后台,提示:安装xx的路由管家,我不想安装 但是无法找到这个管理后台。 而且我是用这个路由作为中继,那么这个路由的ip就会经常更换 尝试通过网上搜索引擎来…