灰度发布是指在黑与白之间,能够平滑过渡的一种发布方式。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;
}
}