美文网首页
Openresty 配合 redis 实现无感知灰度发布系统(基

Openresty 配合 redis 实现无感知灰度发布系统(基

作者: 代码宇宙 | 来源:发表于2020-03-18 16:32 被阅读0次

    Openresty 实现无感知灰度发布系统(基础篇)

    Openresty 是基于 nginx 的一个成熟的网络平台,集成 nginx 和加强的 luajit,许多实用的 lua 库和一些高品质高性能的第三方 nginx 模块。

    本文将使用 Openresty 来搭建一个简单的灰度发布系统。环境为 Cenos7。

    安装 Openresty

    参见 链接: https://blog.csdn.net/weixin_42085428/article/details/104883484.

    配置 Nginx

    在用户目录下创建工作目录,创建 nginx.conf 配置文件,目录结构如下图:


    在这里插入图片描述

    nginx配置文件:

    worker_processes  1;
    error_log logs/error.log;
    events {
        worker_connections 1024;
    }
    
    
    # 通过 redis 获取灰度用户区间,执行灰度操作
    # 灰度测试完毕后,所有用户切换到灰度服务器,更新正式服务器
    # 清空灰度服务器列表
    
    http {
        # 灰度服务器
        upstream grayscale.server{
            server 127.0.0.1:9090;
        }
    
        # 正式服务器
        upstream prod.server{
            server 127.0.0.1:8080;
        }
    
        server {
            listen 1111;
            location / {
                expires 5s;
                # 默认为生产环境
                set $target 'prod.server';
                default_type text/html;
                access_by_lua_file /Users/wangjie/data/nginx/lua/grayscale.lua;
                proxy_pass $scheme://$target$request_uri;
            }
        }
    }
    

    grayscale.lua 代码:

    --[[ 
    # 解决方案
    # redis 中存储用户token 对应用户id
    # redis 中存储灰度用户id区间
    # 通过 token 获取用户 id 判断是否在灰度用户区间内
    ]]
    
    local cjson = require('cjson')
    local redis = require('resty.redis')
    local red = redis:new()
    red:connect("127.0.0.1",6379)
    
    -- 灰度区间
    local Grayscale_Range = red:get("Grayscale_Range")
    local Grayscale_Range_Obj = cjson.decode(Grayscale_Range)
    local IdStart = tonumber(Grayscale_Range_Obj.idStart)
    local IdEnd = tonumber(Grayscale_Range_Obj.idEnd)
    
    -- 用户信息
    local UserToken = ngx.req.get_headers()["TOKEN"]
    local UserId = tonumber(red:get("TOKEN_"..UserToken))
    
    
    if (UserToken != nil)
    then
        if ((UserId > IdStart) and (UserId < IdEnd))
        then
            ngx.var.target = "grayscale.server"
        end
    end
    

    创建两个web服务

    创建两个 web服务,这里我使用 springboot 创建了两个简单的接口用于模拟灰度和生产环境
    分别返回如下内容


    在这里插入图片描述

    启动 redis 服务

    redis 服务,代码写的是 6379 无密码,如果有密码加一句 在red:auth("密码") 即可。
    在 DB0 中新增两个值如下

    // 原样拷贝即可
    Grayscale_Range = {
        "idStart":1,
        "idEnd":5000
    }
    
    TOKEN_HGdsakGDKSFGkgcshalGF = 1234
    

    测试

    使用 postman 请求 http://localhost:1111/api/test1 并携带 TOKEN 请求头(HGdsakGDKSFGkgcshalGF)时,返回灰度环境内容

    在这里插入图片描述

    修改 redis 键 Grayscale_Range 的值为

    {
        "idStart":1,
        "idEnd":100
    }
    

    再次请求,发现已经切换回生产环境


    在这里插入图片描述

    至此,大功告成

    说明

    Openresty 很强大,本示例只是演示如何开始使用它

    欢迎关注公众号:《代码宇宙》 阅读技术相关进阶内容

    相关文章

      网友评论

          本文标题:Openresty 配合 redis 实现无感知灰度发布系统(基

          本文链接:https://www.haomeiwen.com/subject/culcyhtx.html