Nginx灰度发布----【cookie】、【IP】

2022-11-21 20:29:02 浏览数 (1)

灰度发布是指在黑与白之间,能够平滑过渡的一种发布方式。AB test就是一种灰度发布方式,让一部分用户继续用A,一部分用户开始用B,如果用户对B没有什么反对意见,那么逐步扩大范围,把所有用户都迁移到B上面来。

灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调整问题,以保证其影响度。

A/B测试流程

Nginx根据Cookie实现灰度发布


根据Cookie查询Cookie键为version的值,如果该Cookie值为V1则转发到tomcat1,为V2则转发到tomcat2。Cookie值都不匹配的情况下默认走tomcat1所对应的服务器。

两台服务器分别定义为:

代码语言:javascript复制
tomcat1  192.168.1.80:8888
tomcat2  192.168.1.80:8080
用if指令实现
代码语言:javascript复制
    upstream tomcat1 {
      server 192.168.1.80:8888 max_fails=1 fail_timeout=60;
}
    upstream tomcat2 {
      server 192.168.1.80:8080 max_fails=1 fail_timeout=60;
}
    upstream default {
      server 192.168.1.80:8888 max_fails=1 fail_timeout=60;
}
    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
#        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;
  set $group "default";
    if ($http_cookie ~* "version=V1"){
        set $group tomcat1;
    }

    if ($http_cookie ~* "version=V2"){
        set $group tomcat2;
    }
        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;
        }
}

访问测试 http://192.168.1.80

  • 没有cookie值
  • 设置cookie值为version=V1
  • 设置cookie值为version=V2
用map指令实现

在Nginx里面配置一个映射, COOKIE_version可以解析出Cookie里面的version字段。group是一个变量,{}里面是映射规则。

如果一个version为V1的用户来访问, group就等于tomcat1。在server里面使用就会代理到http://tomcat1上。version为V2的用户来访问,group就等于tomcat2。在server里面使用就会代理到http://tomcat2上。Cookie值都不匹配的情况下默认走tomcat1所对应的服务器。

代码语言:javascript复制
    upstream tomcat1 {
      server 192.168.1.80:8888 max_fails=1 fail_timeout=60;
}
    upstream tomcat2 {
      server 192.168.1.80:8080 max_fails=1 fail_timeout=60;
}
    upstream default {
      server 192.168.1.80:8888 max_fails=1 fail_timeout=60;
}
    map $COOKIE_version $group {
      ~*V1$ tomcat1;
      ~*V2$ tomcat2;
      default default;
    }
    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
#        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        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,则反向代理到tomcat2(预发布环境);如果不是则反向代理到tomcat1(生产环境)

代码语言:javascript复制
    upstream tomcat1 {
      server 192.168.1.80:8888 max_fails=1 fail_timeout=60;
}
    upstream tomcat2 {
      server 192.168.1.80:8080 max_fails=1 fail_timeout=60;
}
    upstream default {
      server 192.168.1.80:8888 max_fails=1 fail_timeout=60;
}

    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
#        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;
  set $group default;
  if ($remote_addr ~ "192.168.1.250") {
      set $group tomcat2;
  }
        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;
        }
}

从本机浏览器访问得时候为192.168.1.250

从服务器内网去访问得时候为127.0.0.1

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

代码语言:javascript复制
server {
  listen 80;
  server_name  www.XXXXX.com;
  access_log  logs/www.XXXX.com.log  main;

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

    location / {
      root $rootdir;
    }
}

0 人点赞