成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

使用 caddy 作為微服務(wù)的 API gateway

Lemon_95 / 911人閱讀

摘要:它同時(shí)也和微服務(wù)架構(gòu)相互促進(jìn),并肩前行。為了反向代理的速度,會(huì)和后端保持一個(gè)連接池。好了,現(xiàn)在我們可以知道,可以很好的勝任微服務(wù)架構(gòu)中的了。我認(rèn)為并不適合微服務(wù)架構(gòu),但依然是有個(gè)復(fù)雜的架構(gòu)方案的,這個(gè)主題改天再說。

背景

大家都知道,Docker這些年讓IT界產(chǎn)生了深刻的變革,
從開發(fā)到測(cè)試到運(yùn)維,處處都有它的身影。
它同時(shí)也和微服務(wù)架構(gòu)相互促進(jìn),并肩前行。

在最新版的 Docker(CE 17.03) 里,隨著 swarm mode 的成熟,
在較簡(jiǎn)單的場(chǎng)景里已經(jīng)可以不再需要專門的基礎(chǔ)設(shè)施管理,
服務(wù)編排,服務(wù)發(fā)現(xiàn),健康檢查,負(fù)載均衡等等。

但是API gateway還是需要一個(gè)的?;蛟S再加上一個(gè)日志收集
你的微服務(wù)架構(gòu)就五臟俱全了。
我們知道Nginx Plus是可以很好的勝任 API gateway 的工作的,
但它是商業(yè)軟件。Nginx我們不說認(rèn)證啊限流啊統(tǒng)計(jì)啊之類的功能,
單就請(qǐng)求轉(zhuǎn)發(fā)這一點(diǎn)最基本的就出了問題。

我們知道Docker是用DNS的方式,均衡同一名稱的服務(wù)請(qǐng)求到不同的node,
但是Nginx為了速度,在反向代理的時(shí)候會(huì)有一個(gè)不可取消的 DNS Cache,
這樣我們Docker在根據(jù)容器的擴(kuò)展或收縮動(dòng)態(tài)的更新DNS,可Nginx卻不為所動(dòng),
堅(jiān)持把請(qǐng)求往固定的IP上發(fā),不說均衡,這個(gè)IP甚至可能已經(jīng)失效了呢。

有一個(gè)配置文件上的小Hack可以實(shí)現(xiàn)Nginx每次去查詢DNS,我本來準(zhǔn)備寫一篇文章來著,
現(xiàn)在看來不用了,我們找到了更優(yōu)雅的API gateway, Caddy 。
我上篇文章也寫了一個(gè)它的簡(jiǎn)介。

接下來的所有代碼,都在這個(gè)demo中,
你可以clone下來玩,也能在此基礎(chǔ)上做自己的實(shí)驗(yàn)。

應(yīng)用

我們先用golang寫一個(gè)最簡(jiǎn)單的HTTP API,你可以用你會(huì)的任何語言寫出來,
它為GET請(qǐng)求返回 Hello World 加自己的 hostname .

package main

import (
    "io"
    "log"
    "net/http"
    "os"
)

// HelloServer the web server
func HelloServer(w http.ResponseWriter, req *http.Request) {
    hostname, _ := os.Hostname()
    log.Println(hostname)
    io.WriteString(w, "Hello, world! I am "+hostname+" :)
")
}

func main() {
    http.HandleFunc("/", HelloServer)
    log.Fatal(http.ListenAndServe(":12345", nil))
}
Docker 化

我們需要把上面的應(yīng)用做成一個(gè)docker鏡像,暴露端口12345
接著才有可能使用Docker Swarm啟動(dòng)成集群。
本來做鏡像特別簡(jiǎn)單,但我為了讓大家直接拉鏡像測(cè)試時(shí)快一點(diǎn),用了兩步構(gòu)建,
先編譯出應(yīng)用,然后添加到比較小的alpine鏡像中。大家可以不必在意這些細(xì)節(jié)。
我們還是先來看看最終的docker-compose.yml編排文件吧。

version: "3"
services:
    app:
        image: muninn/caddy-microservice:app
        deploy:
            replicas: 3
    gateway:
        image: muninn/caddy-microservice:gateway
        ports:
            - 2015:2015
        depends_on:
            - app
        deploy:
            replicas: 1
            placement:
                constraints: [node.role == manager]

這是最新版本的docker-compose文件,不再由docker-compose命令啟動(dòng),而是要用docker stack deploy命令。
總之現(xiàn)在這個(gè)版本在編排方面還沒有完全整合好,有點(diǎn)暈,不過能用。現(xiàn)在我們看到編排中有兩個(gè)鏡像:

muninn/caddy-microservice:app 這是我們上一節(jié)說的app鏡像,我們將啟動(dòng)3個(gè)實(shí)例,測(cè)試上層的負(fù)載均衡。

muninn/caddy-microservice:gateway 這是我們接下來要講的gateway了,它監(jiān)聽2015端口并將請(qǐng)求轉(zhuǎn)發(fā)給app。

用 caddy 當(dāng)作 gateway

為了讓caddy當(dāng)作gateway,我們主要來看一下Caddyfile:

:2015 {
    proxy / app:12345
}

好吧,它太簡(jiǎn)單了。它監(jiān)聽本機(jī)的2015端口,將所有的請(qǐng)求都轉(zhuǎn)發(fā)到 app:12345 。
這個(gè)app,其實(shí)是一個(gè)域名,在docker swarm的網(wǎng)絡(luò)中,它會(huì)被解析到這個(gè)名字服務(wù)隨機(jī)的一個(gè)實(shí)例。

將來如果有很多app,將不同的請(qǐng)求前綴轉(zhuǎn)發(fā)到不同的app就好啦。
所以記得寫規(guī)范的時(shí)候讓一個(gè)app的endpoint前綴盡量用一樣的。

然后caddy也需要被容器化,感興趣的可以看看Dockerfile.gateway .

運(yùn)行服務(wù)端

理解了上面的內(nèi)容,就可以開始運(yùn)行服務(wù)端了。直接用我上傳到云端的鏡像就可以。本文用到的三個(gè)鏡像下載時(shí)總計(jì)26M左右,不大。
clone我背景章節(jié)提到的庫進(jìn)入項(xiàng)目目錄,或者僅僅復(fù)制上文提到的compose文件存成docker-compose.yml,然后執(zhí)行如下命令。

docker-compose pull
docker stack deploy -c docker-compose.yml caddy

啊,對(duì)了,第二個(gè)stack命令需要你已經(jīng)將docker切到了swarm模式,如果沒有會(huì)自動(dòng)出來提示,根據(jù)提示切換即可。
如果成功了,我們檢查下狀態(tài):

docker stack ps caddy

如果沒問題,我們能看到已經(jīng)啟動(dòng)了3個(gè)app和一個(gè)gateway。然后我們來測(cè)試這個(gè)gateway是否能將請(qǐng)求分配到三個(gè)后端。

測(cè)試

我們是可以通過訪問http://{your-host-ip}:2015來測(cè)試服務(wù)是不是通的,用瀏覽器或者curl。
然后你會(huì)發(fā)現(xiàn),怎么刷新內(nèi)容都不變啊,并沒有像想象中的那樣會(huì)訪問到隨機(jī)的后端。

不要著急,這個(gè)現(xiàn)象并非因?yàn)閏addy像nginx那樣緩存了dns導(dǎo)致均衡失敗,而是另一個(gè)原因。
caddy為了反向代理的速度,會(huì)和后端保持一個(gè)連接池。當(dāng)只有一個(gè)客戶端的時(shí)候,用到總是那第一個(gè)連接呢。
為了證明這一點(diǎn),我們需要并發(fā)的訪問我們的服務(wù),再看看是否符合我們的預(yù)期。

同樣的,測(cè)試我也為大家準(zhǔn)備了鏡像,可以直接通過docker使用。

docker run --rm -it muninn/caddy-microservice:client

感興趣的人可以看client文件夾里的代碼,它同時(shí)發(fā)起了30個(gè)請(qǐng)求,并且打印出了3個(gè)后端被命中的次數(shù)。

另外我還做了一個(gè)shell版本,只需要sh test.sh就可以,不過只能看輸出拉,沒有自動(dòng)檢查結(jié)果。

好了,現(xiàn)在我們可以知道,caddy可以很好的勝任微服務(wù)架構(gòu)中的 API Gateway 了。

API Gateway

什么?你說沒看出來這是個(gè) API Gateway 啊。我們前邊只是解決了容器項(xiàng)目中 API Gateway 和DNS式服務(wù)發(fā)現(xiàn)配合的一個(gè)難題,
接下來就簡(jiǎn)單了啊,我們寫n個(gè)app,每個(gè)app是一個(gè)微服務(wù),在gateway中把不同的url路由到不同的app就好了啊。

進(jìn)階

caddy還可以輕松的順便把認(rèn)證中心做了,微服務(wù)建議用jwt做認(rèn)證,將權(quán)限攜帶在token中,caddy稍微配置下就可以。
我后續(xù)也會(huì)給出教程和demo 。auth2.0我認(rèn)為并不適合微服務(wù)架構(gòu),但依然是有個(gè)復(fù)雜的架構(gòu)方案的,這個(gè)主題改天再說。

caddy還可以做API狀態(tài)監(jiān)控,緩存,限流等API gateway的職責(zé),不過這些就要你進(jìn)行一些開發(fā)了。
你還有什么更多的想法嗎?歡迎留言。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/26826.html

相關(guān)文章

  • 使用 caddy 作為服務(wù) API gateway

    摘要:它同時(shí)也和微服務(wù)架構(gòu)相互促進(jìn),并肩前行。為了反向代理的速度,會(huì)和后端保持一個(gè)連接池。好了,現(xiàn)在我們可以知道,可以很好的勝任微服務(wù)架構(gòu)中的了。我認(rèn)為并不適合微服務(wù)架構(gòu),但依然是有個(gè)復(fù)雜的架構(gòu)方案的,這個(gè)主題改天再說。 背景 大家都知道,Docker這些年讓IT界產(chǎn)生了深刻的變革,從開發(fā)到測(cè)試到運(yùn)維,處處都有它的身影。它同時(shí)也和微服務(wù)架構(gòu)相互促進(jìn),并肩前行。 在最新版的 Docker(CE...

    jubincn 評(píng)論0 收藏0
  • 新興web服務(wù)caddy

    摘要:是一個(gè)像或的服務(wù)器。得益于的特性,只是一個(gè)小小的二進(jìn)制文件,沒有依賴,很好部署。我們來試試在當(dāng)前目錄創(chuàng)建這樣一個(gè)叫的文件這次,我們改變了端口,并且啟用了自動(dòng)壓縮數(shù)據(jù)。據(jù)說全世界四分之一的站點(diǎn)都是搭建的,而公認(rèn)是世界上最好的語言。 caddy 是一個(gè)像 Apache, nginx, 或 lighttpd 的web服務(wù)器。你要問nginx已經(jīng)很好了,為什么要用caddy呢? 我覺得cadd...

    CollinPeng 評(píng)論0 收藏0
  • 清新脫俗 Web 服務(wù)Caddy

    摘要:清新脫俗的服務(wù)器作為新興服務(wù)器,提供了很多簡(jiǎn)單易用的功能而沒有歷史的包袱,其默認(rèn)支持并且能幫你自動(dòng)配置,對(duì)于都有很好的支持。 清新脫俗的 Web 服務(wù)器 Caddy 從屬于筆者的服務(wù)端應(yīng)用程序開發(fā)與系統(tǒng)架構(gòu),我司之前一直使用 Nginx,不過其配置包括一些特性支持相較于 Caddy 略顯復(fù)雜,可以參考筆者的 Nginx 基本配置備忘。 showImg(https://segmentf...

    alphahans 評(píng)論0 收藏0
  • 清新脫俗 Web 服務(wù)Caddy

    摘要:清新脫俗的服務(wù)器作為新興服務(wù)器,提供了很多簡(jiǎn)單易用的功能而沒有歷史的包袱,其默認(rèn)支持并且能幫你自動(dòng)配置,對(duì)于都有很好的支持。 清新脫俗的 Web 服務(wù)器 Caddy 從屬于筆者的服務(wù)端應(yīng)用程序開發(fā)與系統(tǒng)架構(gòu),我司之前一直使用 Nginx,不過其配置包括一些特性支持相較于 Caddy 略顯復(fù)雜,可以參考筆者的 Nginx 基本配置備忘。 showImg(https://segmentf...

    raledong 評(píng)論0 收藏0
  • [譯] 用 Node.js 搭建 API Gateway

    摘要:協(xié)議轉(zhuǎn)換微服務(wù)架構(gòu)允許使用不同的協(xié)議以便于獲得使用不同技術(shù)的優(yōu)勢(shì)。過于龐大的在實(shí)現(xiàn)時(shí),應(yīng)當(dāng)避免將非通用邏輯如領(lǐng)域特定數(shù)據(jù)轉(zhuǎn)換放入其中。服務(wù)應(yīng)始終對(duì)其數(shù)據(jù)域擁有完全的所有權(quán)。構(gòu)建一個(gè)過于龐大的,從服務(wù)團(tuán)隊(duì)爭(zhēng)奪控制權(quán),這違反了微服務(wù)的理念。 我們團(tuán)隊(duì)的后端服務(wù)中,一開始只有一個(gè)大服務(wù),所有的東西都往里面寫,可以想象下,當(dāng)這個(gè)服務(wù)變得不斷的龐大,將會(huì)變得多么難以維護(hù)。后來逐漸把一些數(shù)據(jù)服務(wù)抽...

    鄒強(qiáng) 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<