设为首页 收藏本站
查看: 1492|回复: 0

[经验分享] 使用Nginx实现灰度发布

[复制链接]

尚未签到

发表于 2017-12-23 09:15:37 | 显示全部楼层 |阅读模式
  灰度发布是指在黑与白之间,能够平滑过渡的一种发布方式。AB test就是一种灰度发布方式,让一部分用户继续用A,一部分用户开始用B,如果用户对B没有什么反对意见,那么逐步扩大范围,把所有用户都迁移到B上面来。
  灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调整问题,以保证其影响度。
  灰度发布常见一般有三种方式:


  •   Nginx+LUA方式

  •   根据Cookie实现灰度发布

  •   根据来路IP实现灰度发布

  本文主要将讲解根据Cookie和来路IP这两种方式实现简单的灰度发布,Nginx+LUA这种方式涉及内容太多就不再本文展开了。
  A/B测试流程
DSC0000.jpg

DSC0001.jpg

  Nginx根据Cookie实现灰度发布
  根据Cookie查询Cookie键为version的值,如果该Cookie值为V1则转发到hilinux_01,为V2则转发到hilinux_02。Cookie值都不匹配的情况下默认走hilinux_01所对应的服务器。
  两台服务器分别定义为:
  

hilinux_01  192.168.1.100:8080  
hilinux_02  192.168.1.200:8080
  


  •   用if指令实现

  

upstream hilinux_01 {  server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
  
}
  

  
upstream hilinux_02 {
  server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
  
}
  

  
upstream default {
  server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
  
}
  

  
server {
  listen 80;
  server_name  www.hi-linux.com;
  access_log  logs/www.hi-linux.com.log  main;
  

  #match cookie
  set $group "default";
  if ($http_cookie ~* "version=V1"){
  set $group hilinux_01;
  }
  

  if ($http_cookie ~* "version=V2"){
  set $group hilinux_02;
  }
  

  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;
  }
  }
  


  •   用map指令实现

  在Nginx里面配置一个映射,$COOKIE_version可以解析出Cookie里面的version字段。$group是一个变量,{}里面是映射规则。
  如果一个version为V1的用户来访问,$group就等于hilinux_01。在server里面使用就会代理到http://hilinux_01上。version为V2的用户来访问,$group就等于hilinux_02。在server里面使用就会代理到http://hilinux_02上。Cookie值都不匹配的情况下默认走hilinux_01所对应的服务器。
  

upstream hilinux_01 {  server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
  
}
  

  
upstream hilinux_02 {
  server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
  
}
  

  
upstream default {
  server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
  
}
  

  
map $COOKIE_version $group {
  
~*V1$ hilinux_01;
  
~*V2$ hilinux_02;
  
default default;
  
}
  

  
server {
  listen 80;
  server_name  www.hi-linux.com;
  access_log  logs/www.hi-linux.com.log  main;
  

  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;
  }
  }
  

Nginx根据来路IP实现灰度发布
  如果是内部IP,则反向代理到hilinux_02(预发布环境);如果不是则反向代理到hilinux_01(生产环境)。
  

upstream hilinux_01 {  server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
  
}
  

  
upstream hilinux_02 {
  server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
  
}
  

  
upstream default {
  server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
  
}
  

  
server {
  listen 80;
  server_name  www.hi-linux.com;
  access_log  logs/www.hi-linux.com.log  main;
  

  set $group default;
  if ($remote_addr ~ "211.118.119.11") {
  set $group hilinux_02;
  }
  

  
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;
  }
  
}
  

  如果你只有单台服务器,可以根据不同的IP设置不同的网站根目录来达到相同的目的。
  

server {  listen 80;
  server_name  www.hi-linux.com;
  access_log  logs/www.hi-linux.com.log  main;
  

  set $rootdir "/var/www/html";
  if ($remote_addr ~ "211.118.119.11") {
  set $rootdir "/var/www/test";
  }
  

  location / {
  root $rootdir;
  }
  
}
  

  到此最基本的实现灰度发布方法就讲解完了,如果要做更细粒度灰度发布可参考ABTestingGateway项目。

  ABTestingGateway是新浪开源的一个动态路由系统。ABTestingGateway是一个可以动态设置分流策略的灰度发布系统,工作在7层,基于nginx和ngx-lua开发,使用redis作为分流策略数据库,可以实现动态调度功能。
  ABTestingGateway:https://github.com/CNSRE/ABTestingGateway


参考文档
  http://www.google.com
  http://www.jianshu.com/p/88f206f48278
  http://blog.chinaunix.net/uid-531464-id-4140473.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-427076-1-1.html 上篇帖子: nginx 、tomcat 集群配置、shiro Session 共享 下篇帖子: Nginx使用教程(七):使用Nginx缓存之proxy cache
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表