亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

軟件開發(fā)一般不會上來就是最終版本,而是會一個版本一個版本的迭代。

新版本上線前都會經(jīng)過測試,但就算這樣,也不能保證上線了不出問題。

所以,在公司里上線新版本代碼一般都是通過灰度系統(tǒng)。

灰度系統(tǒng)可以把流量劃分成多份,一份走新版本代碼,一份走老版本代碼。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

而且灰度系統(tǒng)支持設(shè)置流量的比例,比如可以把走新版本代碼的流程設(shè)置為 5%,沒啥問題再放到 10%,50%,最后放到 100% 全量。

這樣可以把出現(xiàn)問題的影響降到最低。

不然一上來就全量,萬一出了線上問題,那就是大事故。

而且灰度系統(tǒng)不止這一個用途,比如產(chǎn)品不確定某些改動是不是要的,就要做 AB 實驗,也就是要把流量分成兩份,一份走 A 版本代碼,一份走 B 版本代碼。

那這樣的灰度系統(tǒng)是怎么實現(xiàn)的呢?

其實很多都是用 nginx 實現(xiàn)的。

nginx 是一個反向代理的服務(wù),用戶請求發(fā)給它,由它轉(zhuǎn)發(fā)給具體的應(yīng)用服務(wù)器。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

這一層也叫做網(wǎng)關(guān)層。

由它負(fù)責(zé)轉(zhuǎn)發(fā)請求給應(yīng)用服務(wù)器,那自然就可以在這里控制流量的分配,哪些流量走版本 A,哪些流量走版本 B。

下面我們實現(xiàn)一下:

首先,我們準(zhǔn)備兩個版本的代碼。

這里創(chuàng)建個 nest 項目:

npx nest new gray_test -p npm

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

把 nest 服務(wù)跑起來:

npm run start

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

瀏覽器訪問下:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

看到 hello world 代表 nest 服務(wù)跑起來了。

然后改下 AppService:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

修改下端口:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

然后再 npm run start

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

瀏覽器訪問下:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

現(xiàn)在我們就有了兩個版本的 nest 代碼。

接下來的問題是,如何用 nginx 實現(xiàn)灰度,讓一部分請求走一個版本的代碼,一部分請求走另一個版本呢?

我們先跑一個 nginx 服務(wù)。

docker desktop 搜索 nginx 鏡像(這步需要科學(xué)上網(wǎng)),點擊 run:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

設(shè)置容器名為 gray1,端口映射宿主機的 82 到容器內(nèi)的 80

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

現(xiàn)在訪問 http://localhost:82 就可以看到 nginx 頁面了:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

我們要修改下配置文件,把它復(fù)制出來:

docker cp gray1:/etc/nginx/conf.d ~/nginx-config

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

然后編輯下這個 default.conf

添加這么一行配置:

location ^~ /api {
    rewrite ^/api/(.*)$ /$1 break;
    proxy_pass http://192.168.1.6:3001;
}

這行就是加了一個路由,把 /api/ 開頭的請求轉(zhuǎn)發(fā)給 http://宿主機IP:3001 這個服務(wù)。

用 rewrite 把 url 重寫了,比如 /api/xxx 變成了 /xxx。

然后我們重新跑個 nginx 容器:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

容器名為 gray2,端口映射 83 到容器內(nèi)的 80。

指定數(shù)據(jù)卷,掛載本地的 ~/nginx-config 目錄到容器內(nèi)的 /etc/nginx/conf.d 目錄。

點擊 run。

然后看下 files 部分:

可以看到容器內(nèi)的 /etc/nginx/conf.d 目錄標(biāo)識為了 mounted。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

點開看看:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

這就是本地的那個文件。

我們在本地改一下試試:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

容器內(nèi)也同樣修改了。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

在容器內(nèi)修改這個文件,本地同樣也會修改。

也就是說掛載數(shù)據(jù)卷之后,容器內(nèi)的這個目錄就是本地目錄,是同一份。

然后我們訪問下 http://localhost:83/api/ 看看:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

nest 服務(wù)訪問成功了。

現(xiàn)在我們不是直接訪問 nest 服務(wù)了,而是經(jīng)歷了一層 nginx 反向代理或者說網(wǎng)關(guān)層。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

自然,我們可以在這一層實現(xiàn)流量控制的功能。

前面我們講負(fù)載均衡的時候,是這么配的:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

默認(rèn)會輪詢把請求發(fā)給 upstream 下的 server。

現(xiàn)在需要有多組 upstream:

upstream version1.0_server {
    server 192.168.1.6:3000;
}
upstream version2.0_server {
    server 192.168.1.6:3001;
}
upstream default {
    server 192.168.1.6:3000;
}

有版本 1.0 的、版本 2.0 的,默認(rèn)的 server 列表。

然后需要根據(jù)某個條件來區(qū)分轉(zhuǎn)發(fā)給哪個服務(wù)。

我們這里根據(jù) cookie 來區(qū)分:

set $group "default";
if ($http_cookie ~* "version=1.0"){
    set $group version1.0_server;
}
if ($http_cookie ~* "version=2.0"){
    set $group version2.0_server;
}
location ^~ /api {
    rewrite ^/api/(.*)$ /$1 break;
    proxy_pass http://$group;
}

如果包含 version=1.0 的 cookie,那就走 version1.0_server 的服務(wù),有 version=2.0 的 cookie 就走 version2.0_server 的服務(wù),否則,走默認(rèn)的。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

這樣就實現(xiàn)了流量的劃分,也就是灰度的功能。

然后我們重新跑下容器:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

這時候,你訪問 http://localhost:83/api/ 走到的就是默認(rèn)的版本。

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

然后帶上 version=2.0 的 cookie,走到的就是另一個版本的代碼:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

這樣,我們就實現(xiàn)了灰度的功能。

但現(xiàn)在還有一個問題:

什么時候設(shè)置的這個 cookie 呢?

比如我想實現(xiàn) 80% 的流量走版本 1.0,20% 的流量走版本 2.0

其實公司內(nèi)部一般都有灰度配置系統(tǒng),可以配置不同的版本的比例,然后流量經(jīng)過這個系統(tǒng)之后,就會返回 Set-Cookie 的 header,里面按照比例來分別設(shè)置不同的 cookie。

比如隨機數(shù)載 0 到 0.2 之間,就設(shè)置 version=2.0 的 cookie,否則,設(shè)置 version=1.0 的 cookie。

這也叫做流量染色。

完整的灰度流程是這樣的:

基于Nginx實現(xiàn)一個灰度上線系統(tǒng)的示例代碼

第一次請求的時候,會按照設(shè)定的比例隨機對流量染色,也就是設(shè)置不同 cookie。

再次訪問的時候會根據(jù) cookie 來走到不同版本的代碼。

這就實現(xiàn)了灰度功能,可以用來做 5% 10% 50% 100% 這樣逐步上線的灰度上線機制。

也可以用來做產(chǎn)品的 AB 實驗。

公司里都會用這樣的灰度系統(tǒng)。

總結(jié)

新版本代碼的上線基本都會用灰度系統(tǒng),可以逐步放量的方式來保證上線過程不會出大問題,也可以用來做產(chǎn)品 AB 實驗。

我們可以用 nginx 實現(xiàn)這樣的功能。

nginx 有反向代理的功能,可以轉(zhuǎn)發(fā)請求到應(yīng)用服務(wù)器,也叫做網(wǎng)關(guān)層。

我們可以在這一層根據(jù) cookie 里的 version 字段來決定轉(zhuǎn)發(fā)請求到哪個服務(wù)。

在這之前,還需要按照比例來給流量染色,也就是返回不同的 cookie。

不管灰度系統(tǒng)做的有多復(fù)雜,底層也就是流量染色、根據(jù)標(biāo)記轉(zhuǎn)發(fā)流量這兩部分,我們完全可以自己實現(xiàn)一個。

分享到:
標(biāo)簽:上線 代碼 服務(wù)器 灰度 示例
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運動步數(shù)有氧達(dá)人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定