基于cookie在nginx实现业务灰度发布
基于cookie在nginx实现业务灰度发布
背景
灰度发布是指在黑与白之间,能够平滑过渡的一种发布方式。
灰度发布可以保证整体系统的稳定,
在初始灰度的时候就可以发现、调整问题,以保证其影响度。
业务存在灰度发布的需求,
可以通过nginx+lua形式实现业务的灰度发布,
目前这一形式已在广平互动广告相关业务已经实现。
流程
用户使用帐号登录后,判断用户帐号是否在灰度发布的名单中,如果再则给用户的cookie中增加灰度发布标识,然后刷新页面。
当用户访问页面时,业务接入层的nginx方向代理会根据用户cookie是否带着灰度标识而对用户的请求进行选择,是转发到所有后端机器还是指定的灰度发布机器。
方案
业务维护一个用户帐号的灰度名单,在程序里面实现灰度帐号登录时cookie里面种相应的标识。
用户请求发起时,nginx反向代理接入层通过获取请求中带的cookie的相关变量来判断当前请求是发往全量的服务器,还是发往灰度的服务器。
灰度处理逻辑
nginx接入层
配置实例
nginx配置静态页面的灰度规则
server
{
listen 80;
server_name test.qunyingliu.qq.com;
access_log logs/test.qunyingliu.qq.com.access.log access;
设置默认为全量发布
set $group "Full";
判断cookie中是否有灰度标识号
if ($http_cookie ~* "FC_GREY=1"){
set $group Grey;
}
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配置PHP页面的灰度规则
location @grey {
proxy_next_upstream http_500 http_502 http_503 http_504 error timeout invalid_header;
add_header ENV 'grey';
proxy_pass http://Grey;
}
location @full {
proxy_next_upstream http_500 http_502 http_503 http_504 error timeout invalid_header;
add_header ENV 'full';
proxy_pass http://FULL;
}
location ~ \.(php)?$ {
content_by_lua_file "conf/lua/test.qunyingliu.qq.com.lua";
}
test.qunyingliu.qq.com.lua:
local ck = require "resty.cookie"
local grey_cookie_key = "FC_GREY"
local cookie, err = ck:new()
if not cookie then
ngx.exec("@full")
else
local field, err = cookie:get(grey_cookie_key)
if not field then
ngx.exec("@full")
else
ngx.exec("@grey")
end
end
灰度验证
1.浏览器控制台设置灰度cookie
console---> setCookie('FC_GREY',1)
2.chrome扩展:EditThisCookie--->"+"---->添加新cookie
3.业务里面给用户设置cookie
总结
需要业务端配合才能实现自动的灰度发布,
主要规则是在nginx上使用lua脚本进行处理,
请求的速度和稳定性可能会收到lua脚本处理的影响,
界面普遍认为nginx+lua是非常好的搭配,
相关开源方案OpenResty也是比较热门的,
实际效果还需要在业务上线后进行验证。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
VBS将本地的Excel数据导入到SQL Server中
VBS将本地的Excel数据导入到SQL Server中 最近有个测试,需要将本地的Excel数据导入到SQL Server中,所以就写了一个这个脚本,供有需要的同学进行参考。因为在此演示测试,所以准备的数据都比较简单。 我们准备将本地的Excel的A列插入到数据库中的Username列 首先准备本地的Excel数据 然后准备数据库及表结构 开始上脚本 DimDB,objRecordSet DimExcel 'SQLServer服务器地址 DimSQLserver 'SQLServer数据库 DimDatabase 'SQLServer登录名 Dimuid 'SQLServer登陆密码 Dimpwd 'SQLServer数据库表名 DimTablename 'SQLServer数据库表列字段 DimColumn 'Excel表路劲 DimXLSPath SQLserver="192.168.7.170" Database="PasswordInfo" uid="sa" pwd="Password" tablename="UserServerInfo" column="Username"...
- 下一篇
图文并茂超详细搭建memcache缓存服务器(nginx+php+memcache+mysql)
博主QQ:819594300 博客地址:http://zpf666.blog.51cto.com/ 有什么疑问的朋友可以联系博主,博主会帮你们解答,谢谢支持! 一、MemCache简述 session MemCache是一个自由、源码开放、高性能、分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问的速度。 MemCaChe是一个存储键值对的HashMap,在内存中对任意的数据(比如字符串、对象等)所使用的key-value存储,数据可以来自数据库调用、API调用,或者页面渲染的结果。MemCache设计理念就是小而强大,它简单的设计促进了快速部署、易于开发并解决面对大规模的数据缓存的许多难题,而所开放的API使得MemCache能用于Java、C/C++/C#、Perl、Python、PHP、Ruby等大部分流行的程序语言。 另外,说一下为什么会有Memcache和memcached两种名称?其实Memcache是这个项目的名称,而memcached是它服务器端的主程序文件名 MemCache的官...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8编译安装MySQL8.0.19
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Linux系统CentOS6、CentOS7手动修改IP地址
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装