Openresty 配合 redis 實現無感知灰度發佈系統(基礎篇)

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 很強大,本示例只是演示如何開始使用它

歡迎關注公衆號:《代碼宇宙》 閱讀技術相關進階內容

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章