Openresty 配合 redis 實(shí)現(xiàn)無感知灰度發(fā)布系統(tǒng)(基礎(chǔ)篇)

Openresty 實(shí)現(xiàn)無感知灰度發(fā)布系統(tǒng)(基礎(chǔ)篇)

Openresty 是基于 nginx 的一個(gè)成熟的網(wǎng)絡(luò)平臺(tái),集成 nginx 和加強(qiáng)的 luajit,許多實(shí)用的 lua 庫(kù)和一些高品質(zhì)高性能的第三方 nginx 模塊。

本文將使用 Openresty 來搭建一個(gè)簡(jiǎn)單的灰度發(fā)布系統(tǒng)。環(huán)境為 Cenos7。

安裝 Openresty

參見 鏈接: https://blog.csdn.net/weixin_42085428/article/details/104883484.

配置 Nginx

在用戶目錄下創(chuàng)建工作目錄,創(chuàng)建 nginx.conf 配置文件,目錄結(jié)構(gòu)如下圖:


在這里插入圖片描述

nginx配置文件:

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}


# 通過 redis 獲取灰度用戶區(qū)間,執(zhí)行灰度操作
# 灰度測(cè)試完畢后,所有用戶切換到灰度服務(wù)器,更新正式服務(wù)器
# 清空灰度服務(wù)器列表

http {
    # 灰度服務(wù)器
    upstream grayscale.server{
        server 127.0.0.1:9090;
    }

    # 正式服務(wù)器
    upstream prod.server{
        server 127.0.0.1:8080;
    }

    server {
        listen 1111;
        location / {
            expires 5s;
            # 默認(rèn)為生產(chǎn)環(huán)境
            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 中存儲(chǔ)用戶token 對(duì)應(yīng)用戶id
# redis 中存儲(chǔ)灰度用戶id區(qū)間
# 通過 token 獲取用戶 id 判斷是否在灰度用戶區(qū)間內(nèi)
]]

local cjson = require('cjson')
local redis = require('resty.redis')
local red = redis:new()
red:connect("127.0.0.1",6379)

-- 灰度區(qū)間
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

創(chuàng)建兩個(gè)web服務(wù)

創(chuàng)建兩個(gè) web服務(wù),這里我使用 springboot 創(chuàng)建了兩個(gè)簡(jiǎn)單的接口用于模擬灰度和生產(chǎn)環(huán)境
分別返回如下內(nèi)容


在這里插入圖片描述

啟動(dòng) redis 服務(wù)

redis 服務(wù),代碼寫的是 6379 無密碼,如果有密碼加一句 在red:auth("密碼") 即可。
在 DB0 中新增兩個(gè)值如下

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

測(cè)試

使用 postman 請(qǐng)求 http://localhost:1111/api/test1 并攜帶 TOKEN 請(qǐng)求頭(HGdsakGDKSFGkgcshalGF)時(shí),返回灰度環(huán)境內(nèi)容

在這里插入圖片描述

修改 redis 鍵 Grayscale_Range 的值為

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

再次請(qǐng)求,發(fā)現(xiàn)已經(jīng)切換回生產(chǎn)環(huán)境


在這里插入圖片描述

至此,大功告成

說明

Openresty 很強(qiáng)大,本示例只是演示如何開始使用它

歡迎關(guān)注公眾號(hào):《代碼宇宙》 閱讀技術(shù)相關(guān)進(jìn)階內(nèi)容

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容