灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调整问题,以保证其影响度。
注意,nginx安装时需要安装如下模块,让nginx能获取到客户端真实的ip:
--with-http_realip_module
灰度发布常见一般有三种方式:
- Nginx+LUA方式,本文不介绍。
- 根据Cookie实现灰度发布
- 根据来路IP实现灰度发布
1,Nginx根据Cookie实现灰度发布
根据Cookie查询Cookie键为version的值,如果该Cookie值为V1则转发到server_01,为V2则转发到server_02。Cookie值都不匹配的情况下默认走default所对应的服务器。
if指令实现:
upstream server_01 {
server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}
upstream server_02 {
server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
}
upstream default {
server 192.168.1.300:8080 max_fails=1 fail_timeout=60;
}
server {
listen 80;
server_name www.a.com;
access_log logs/www.a.com.log main;
#match cookie
set $group "default";
if ($http_cookie ~* "version=V1"){
set $group server_01;
}
if ($http_cookie ~* "version=V2"){
set $group server_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里面配置一个映射,
C
O
O
K
I
E
v
e
r
s
i
o
n
可
以
解
析
出
C
o
o
k
i
e
里
面
的
v
e
r
s
i
o
n
字
段
。
COOKIE_version可以解析出Cookie里面的version字段。
COOKIEversion可以解析出Cookie里面的version字段。group是一个变量,{}里面是映射规则。
upstream server_01 {
server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}
upstream server_02 {
server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
}
upstream default {
server 192.168.1.300:8080 max_fails=1 fail_timeout=60;
}
map $COOKIE_version $group {
~*V1$ server_01;
~*V2$ server_02;
default default;
}
server {
listen 80;
server_name www.a.com;
access_log logs/www.a.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;
}
}
2,Nginx根据来路IP实现灰度发布
如果是内部IP,则反向代理到server_02;如果不是则反向代理到server_01。
upstream server_01 {
server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}
upstream server_02 {
server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
}
upstream default {
server 192.168.1.300:8080 max_fails=1 fail_timeout=60;
}
server {
listen 80;
server_name www.a.com;
access_log logs/www.a.com.log main;
set $group default;
if ($remote_addr ~ "ip") {
set $group server_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.a.com;
access_log logs/www.a.com.log main;
set $rootdir "/var/www/html";
if ($remote_addr ~ "ip") {
set $rootdir "/var/www/test";
}
location / {
root $rootdir;
}
}