您当前的位置:首页 > 电脑百科 > 站长技术 > 服务器

Nginx 实现灰度发布的三种方法总结

时间:2019-09-24 09:26:47  来源:  作者:

方式一:通过调节负载均衡权重

负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。

负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

Nginx 实现灰度发布的三种方法总结

 

http { 
 upstream cluster { 
 ip_hash; #如果你的系统中没有使用第三方缓存管理工具 ,建议使用此方式
 server 192.168.1.210:80 weight=5; 
 server 192.168.1.211:80 weight=3; 
 server 192.168.1.212:80 weight=1; 
 } 
 
 server { 
 listen 80; 
 
 location / { 
 
 proxy_next_upstream error timeout;
 proxy_redirect off;
 proxy_set_header Host $host;
 #proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Real-IP $http_x_forwarded_for;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 client_max_body_size 100m;
 client_body_buffer_size 256k;
 proxy_connect_timeout 180;
 proxy_send_timeout 180;
 proxy_read_timeout 180;
 proxy_buffer_size 8k;
 proxy_buffers 8 64k;
 proxy_busy_buffers_size 128k;
 proxy_temp_file_write_size 128k;
 proxy_pass http://cluster; 
 } 
 } 
} 

这种方式灰度发布通过weight来实现,但是这种方式只适合修改节点的行为,而且要求应用都是一模一样的,其实质作用是,节点增加或删除之后,对负载能力的调节,最终目的是为了让流量最终保持均衡。

方式二.使用Nginx+lua实现web项目的灰度发布

location / {
 content_by_lua '
 myIP = ngx.req.get_headers()["X-Real-IP"]
 if myIP == nil then
 myIP = ngx.req.get_headers()["x_forwarded_for"]
 end
 if myIP == nil then
 myIP = ngx.var.remote_addr
 end
 if myIP == "公司出口IP" then
 ngx.exec("@client")
 else
 ngx.exec("@client_test")
 end
 ';
} 
 
location @client{
 proxy_next_upstream error timeout;
 proxy_redirect off;
 proxy_set_header Host $host;
 #proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Real-IP $http_x_forwarded_for;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 client_max_body_size 100m;
 client_body_buffer_size 256k;
 proxy_connect_timeout 180;
 proxy_send_timeout 180;
 proxy_read_timeout 180;
 proxy_buffer_size 8k;
 proxy_buffers 8 64k;
 proxy_busy_buffers_size 128k;
 proxy_temp_file_write_size 128k;
 proxy_pass http://client;
 
}
location @client_test{
 proxy_next_upstream error timeout;
 proxy_redirect off;
 proxy_set_header Host $host;
 #proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Real-IP $http_x_forwarded_for;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 client_max_body_size 100m;
 client_body_buffer_size 256k;
 proxy_connect_timeout 180;
 proxy_send_timeout 180;
 proxy_read_timeout 180;
 proxy_buffer_size 8k;
 proxy_buffers 8 64k;
 proxy_busy_buffers_size 128k;
 proxy_temp_file_write_size 128k;
 proxy_pass http://client_test;
}

由于使用了nginx+lua模块,这种方式适合很多场景,非常强大,但是问题是你可能需要学习很多lua的语法

方式三.使用http头信息判断+权重(灰度值)

http请求传输过程中,会自动带上User-Agent,Host,Referer,Cookie等信息。我们只需要判断ip地址段,用户代理,Cookie中的信息等。我们这里以Cookie为例。

当然,这里需要解决两个问题:

①首次访问静态页面可能不会产生cookie

②我们需要通过代码动态设置路由

③通过weight控制灰度值

我们可以通过一个例子来解决上述中的②与③的问题

upstream tts_V6 {
 server 192.168.3.81:5280 max_fAIls=1 fail_timeout=60;
}
upstream tts_V7 {
 server 192.168.3.81:5380 max_fails=1 fail_timeout=60;
}
upstream default { #通过upstream default + weight节点控制权重
 server 192.168.3.81:5280 max_fails=1 fail_timeout=60 weight=5;
 server 192.168.3.81:5380 max_fails=1 fail_timeout=60 weight=1;
}
server {
 listen 80;
 server_name test.taotaosou.com;
 access_log logs/test.taotaosou.com.log main buffer=32k;
 #match cookie
 set $group "default";
 if ($http_cookie ~* "tts_version_id=tts1"){ #动态控制路由
 set $group tts_V6;
 }
 if ($http_cookie ~* "tts_version_id=tts2"){
 set $group tts_V7;
 }
 location / { 
 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;
 }
 }

对于问题①,我们可以在index页面通过script来访问动态页面:

<script src="https://test.taotaosou.com/cookieinfo.php" /><script>

此外,我们还要在cookieinfo.php中判断和生成cookie

<?php
if(!session_id())
{
 session_start();
}
if(!isset($_COOKIE["tts_version_id"]))
{
 $cookieValue = $_SERVER['SERVER_PORT']==5280?"tts1":"tts2";
 setcookie("tts_version_id", $cookieValue, time()+3600, "/");
}
?>


Tags:Nginx   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Nginx 反向代理为什么叫做“反向”?
今天我们来聊聊正向代理和反向代理。01 正向代理(Forward Proxy)正向代理是位于用户设备和互联网之间的服务器。它代理的是客户端,是站在用户一方的。其真实客户端对于服务器不...【详细内容】
2023-12-06  Search: Nginx  点击:(90)  评论:(0)  加入收藏
Nginx 大揭秘:读写分离助力您轻松征服高并发
引言在构建高性能、高可用的 Web 应用时,如何有效地处理数据库的读写负担已成为一个十分重要的考虑因素。Nginx 作为一款强大的反向代理服务器,提供了简单而灵活的负载均衡配...【详细内容】
2023-11-14  Search: Nginx  点击:(54)  评论:(0)  加入收藏
如何保持会话粘性,看看 Nginx 怎么做的
图片背景最近有个项目需求:来自同一客户端的所有请求都被发送到同一个后端服务器,以确保会话数据或状态在服务器之间保持一致。会话粘性根据上面的需求,其实就是如何实现会话粘...【详细内容】
2023-09-27  Search: Nginx  点击:(234)  评论:(0)  加入收藏
使用 Docker + Nginx 部署前端项目
前端项目除了目前的纯单页应用,还有SSR的应用,例如 nuxt 和 nextjs,其区别在于前者是单独的前端页面部署,而后者使用了一个内部的 node 小型服务器来做到服务器页面直出的效果。...【详细内容】
2023-09-18  Search: Nginx  点击:(238)  评论:(0)  加入收藏
使用Docker搭建Nginx Web服务器
在本文中,我们将介绍如何使用Docker快速搭建Nginx Web服务器。Nginx是现代化的高性能Web服务器,它在目前的Web服务器中表现出色。而使用Docker来搭建环境则使得部署变得更加简...【详细内容】
2023-09-08  Search: Nginx  点击:(335)  评论:(0)  加入收藏
在windows环境下 nginx + .net core 3.1 实现反向代理和负载均衡
一、创建.net core web 应用1、首先打开vs2019创建好.net core web应用,简单的注入IConfiguration 便于打印端口号展示效果。 1 private readonly ILogger<HomeContr...【详细内容】
2023-08-10  Search: Nginx  点击:(202)  评论:(0)  加入收藏
Nginx 常用实践
Nginx 介绍Nginx 是开源、高性能、高可靠的 Web 和反向代理服务器,而且支持热部署,几乎可以做到 7 * 24 小时不间断运行,即使运行几个月也不需要重新启动,还能在不间断服务的情...【详细内容】
2023-08-02  Search: Nginx  点击:(170)  评论:(0)  加入收藏
Nginx 日志文件详解:监控与诊断利器
随着互联网技术的快速发展,Nginx 已成为最受欢迎的 Web 服务器之一,其稳定性、高性能和灵活性备受推崇。Nginx 日志文件是 Nginx 服务器中非常重要的组成部分,对于监控和诊断 W...【详细内容】
2023-06-01  Search: Nginx  点击:(258)  评论:(0)  加入收藏
如何使用Nginx Map指令简化重定向规则,提升用户体验
Nginx是一个高性能的Web服务器,代理服务器和反向代理服务器。它能够处理高并发的请求,并且拥有强大的扩展性和灵活性。在Nginx中,map是一个非常有用的指令,它可以让您定义一个映...【详细内容】
2023-04-21  Search: Nginx  点击:(373)  评论:(0)  加入收藏
使用 Nginx 作为 MySQL 的 TCP 负载均衡器
Overview随着应用程序的膨胀,我们往往需要扩展程序的基础架构。这篇文章是使用 NGINX 作为 MySQL 的 TCP 负载均衡器的实践。 使用 TCP 负载均衡器的好处: 对数据库进行负载...【详细内容】
2023-04-13  Search: Nginx  点击:(191)  评论:(0)  加入收藏
▌简易百科推荐
为什么Nginx被称为“反向”代理呢?
Nginx(发音为"engine-x")是一款高性能、轻量级的开源Web服务器软件,也可用作反向代理服务器、负载均衡器和HTTP缓存。Nginx之所以有被称为“反向”代理,是因为它充当客户端设备...【详细内容】
2024-02-01  coderidea  微信公众号  Tags:Nginx   点击:(61)  评论:(0)  加入收藏
哪种服务器操作系统更好呢?
在当今的IT世界中,服务器操作系统扮演着至关重要的角色。它们是确保服务器能够高效、安全地运行的关键因素。然而,对于许多人来说,服务器操作系统的种类和特点可能是一个复杂的...【详细内容】
2024-01-30    简易百科  Tags:操作系统   点击:(80)  评论:(0)  加入收藏
什么是VPS服务器
VPS服务器是一种虚拟化技术,它将一台物理服务器划分为多个虚拟的独立服务器,每个虚拟服务器都可以拥有自己的操作系统、运行环境、应用程序等。这种技术使得每个虚拟服务器可...【详细内容】
2024-01-30    简易百科  Tags:VPS服务器   点击:(73)  评论:(0)  加入收藏
VPS服务器下载速度慢?这五招帮你提速
VPS服务器下载速度慢可能会让用户感到沮丧,尤其是对于需要大量下载和上传数据的用户。幸运的是,有一些方法可以帮助您提高VPS服务器的下载速度,使您的在线体验更加顺畅。在本文...【详细内容】
2024-01-30  IDC行业观察者    Tags:VPS服务器   点击:(60)  评论:(0)  加入收藏
美国VPS和英国VPS:地理位置对服务器性能的影响
在今天的数字时代,VPS已成为在线业务和网站托管的关键组成部分。然而,选择合适的VPS主机服务时,地理位置通常被忽视,尽管它对服务器性能有着重要的影响。本文将探讨美国VPS和英...【详细内容】
2024-01-26  IDC行业观察者    Tags:服务器   点击:(56)  评论:(0)  加入收藏
如何判断服务器所需带宽:基于业务需求和流量模式的关键考量
在选择服务器时,带宽是一个重要的考虑因素。带宽的大小直接影响到网站的加载速度和用户的访问体验。那么,如何判断服务器需要多大的带宽呢?本文将为你揭示这一关键问题的答案...【详细内容】
2024-01-26  源库科技    Tags:服务器   点击:(78)  评论:(0)  加入收藏
服务器内存空间及IO操作原理解析
服务器的内存空间分为内核空间和用户空间,而我们编写的程序通常在用户空间中运行。在进行读写操作时,我们直接操作的是用户缓冲区,而用户缓冲区的内容来自于内核缓冲区。这种内...【详细内容】
2024-01-23  王建立    Tags:服务器   点击:(45)  评论:(0)  加入收藏
如何在Java环境中安装Nginx?
1. 下载Nginx:首先,前往Nginx官方网站(https://nginx.org/en/download.html)下载新版本的Nginx。选择适合您操作系统的版本,通常有Windows、Linux和Mac等不同操作系统的版本可供...【详细内容】
2024-01-22  敲代码的小动    Tags:Nginx   点击:(69)  评论:(0)  加入收藏
服务器证书和SSL证书有啥区别?
在互联网经济时代,随着越来越多的信息以及合作都是从企业官网开始的,因此绝大多数企业都会为自己的网站配置SSL证书,以提高安全性。在接触SSL证书时,也有很多人称之为服务器证书...【详细内容】
2024-01-10  安信SSL证书    Tags:服务器证书   点击:(66)  评论:(0)  加入收藏
宝塔面板怎样部署java项目?
宝塔面板怎样部署java项目?在使用宝塔面板部署Java项目之前,需要确保已经安装了Java Development Kit (JDK)。接下来,将介绍如何使用宝塔面板来部署Java项目的步骤。步骤一:安装...【详细内容】
2024-01-09  西部数码    Tags:宝塔面板   点击:(119)  评论:(0)  加入收藏
站内最新
站内热门
站内头条