這篇文章將為大家詳細講解有關如何給Ocelot做一個Docker鏡像,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
專注于為中小企業(yè)提供成都網站建設、做網站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)運河免費做網站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網行業(yè)人才,有力地推動了超過千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網站建設實現(xiàn)規(guī)模擴充和轉變。
在微服務架構中,ApiGateway起到了承前啟后,不僅可以根據客戶端進行分類,也可以根據功能業(yè)務進行分類,而且對于服務調用服務也起到了很好的接口作用。目前在各個云端中,基本上都提供了ApiGateway的功能(付費功能),通過SDK或者在線進行配置。
在Java體系中有Zuul和Kong都是比較著名的。
在.Net體系中,目前比較熱門的(短短1年時間已經1000+stars了)
Ocelot,這是一個非常優(yōu)秀的基于 .Net Core的Api網關開源項目,我們的在隊長也參與了開發(fā),過年前又被納入了微軟eShop微服務架構Demo項目中,作為其Api網關,目前正在整合中,有興趣可以關注項目中新的的Ocelot Branch。
基本的使用方式在園中已有博主寫過了,不過內容是之前版本的,新版本稍微有點不同,還是建議大家看文檔。通過文檔我們了解,Ocelot是通過一個json文件進行配置的,所以在使用的時候我們只需要修改這個json文件就可以了,每次為不同的ApiGateway創(chuàng)建不同的項目比較麻煩,So,今天來講下如何把Ocelot做成一個Docker鏡像,這樣使用的時候只需要輸入一條docker指令即可。
今天的Dockerfile我是Fork了Ocelot項目后在自己的Branch中弄的,直接是項目引用,這只是范例而已,你可以重新創(chuàng)建一個專門的項目,通過Nuget管理添加對Ocelot的引用。
創(chuàng)建Dockerfile代碼
Dockerfile只是一個文本文件,它每一行代表Docker鏡像的一個layer,每一行由命令加參數組成,我們通過編寫簡單的命令,就能使用docker工具生成docker鏡像。
首先你要在項目中創(chuàng)建Dockerfile,請記住,把你的Dockerfile放在sln目錄下,因為Dockerfile文件的build環(huán)境是按照你這個文件的目錄來的,切記,博主之前花了N天才發(fā)現(xiàn)這個弱智的問題。docker command對文件名對大小寫敏感。
直接上代碼:
FROM microsoft/aspnetcore:2.0 AS base #基于asp.net core 2.0鏡像 WORKDIR /app EXPOSE 80 # 先使用asp.net core build鏡像,然后復制項目到/src目錄 FROM microsoft/aspnetcore-build:2.0 AS build WORKDIR /src COPY *.sln ./ COPY demos/ApiGateway.Web/ApiGateway.Web.csproj demos/ApiGateway.Web/ COPY src/Ocelot/Ocelot.csproj src/Ocelot/ RUN dotnet restore COPY . . WORKDIR /src/demos/ApiGateway.Web RUN dotnet add package BuildBundlerMinifier #這里添加了對bundle的支持,你可以不使用,因為我更改了樣式,所以這里加上了這個。 RUN dotnet restore RUN dotnet build -c Release -o /app # 編譯以后,我們進行發(fā)布,并直接復制到app目錄 FROM build AS publish RUN dotnet publish -c Release -o /app # 設定app目錄為工作目錄 FROM base AS final WORKDIR /app COPY --from=publish /app . # 掛載/app/configurations目錄 VOLUME /app/Configurations ENTRYPOINT ["dotnet", "ApiGateway.Web.dll"]
上面就是我的Dockerfile文件了,我在項目中并沒有把configuration.json文件放到項目根目錄,而是另外創(chuàng)建了一個Configurations目錄,這樣我掛載目錄,可以在多個容器中共享數據。
生成Docker鏡像
如果你的機器上裝了Docker,那可以通過命令工具,在項目的根目錄運行:
docker build -t myocelot:v1 .
注意這個命令后的.一定不要忘記哦
如果你機器上沒有安裝Docker,也沒有關系,可以通過Docker倉庫或者阿里云的容器管理進行生成,他們都是免費的,博主使用的是阿里云容器管理創(chuàng)建的,這樣每次代碼改動,它會自動生成新的鏡像。
運行容器
當我們有了鏡像后,就可以運行容器了,因為博主用的是阿里云容器管理,所以我需要先把鏡像pull到運行環(huán)境(我用的是阿里云ECS)
docker pull registry.cn-hangzhou.aliyuncs.com/jamesying/ocelot-demo docker tag registry.cn-hangzhou.aliyuncs.com/jamesying/ocelot-demo myocelot:v1
博主通過pull命令拉了鏡像后又通過tag命令重新命名了tagname。
隨后我們創(chuàng)建一個ocelot的配置文件目錄,并創(chuàng)建configurations.json文件:
mkdir /home/ocelot touch /home/ocelot/configurations.json
下面通過vi工具配置你自己的config,下面是博主的:
{
"ReRoutes": [
{
"DownstreamPathTemplate": "/api/values/{id}",
"DownstreamScheme": "http",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 6002
},
{
"Host": "localhost",
"Port": 6001
}
],
"LoadBalancer": "RoundRobin",
"UpstreamPathTemplate": "/api/v1/values/{id}",
"DownstreamHealthcheckPath": "/hc?apikey=testapi",
"UpstreamHttpMethod": [ "GET", "Put", "Delete" ]
}
],
"GlobalConfiguration": {}
}后面我們來運行容器:
docker run --name myocelot -p 6008:80 -v /home/ocelot:/app/configurations -d ocelot:v1
成功運行以后,我們就可以通過6008端口訪問了,你可以通過 http://ocelot.jcsoft.xyz:6008 看下Demo。下圖為演示截圖:

為什么會有這個鏡像呢,因為通過鏡像生成很簡單,而且配置文件更改后,只需要docker restart myocelot就能重新加載,非常簡便。今天的內容很簡單,但很實用,當然這個鏡像還是有點欠缺的,因為Ocelot有很多功能,還需要在Startup.cs中注冊一些service才可以使用,博主有個想法,弄個專門的Ocelot Demo,只需要通過config文件就能自動注冊相應服務。
或許你從Demo中看到了樓主對Ocelot的改動,樓主增加了 DownstreamHealthcheckPath屬性,這個是為了對下游服務器進行Healthcheck的,而且樓主也PR給了Ocelot的項目負責人,不過Tom不太清楚這個屬性有何用,所以我準備做個Demo給他看下,這個屬性很有用,除了可以通過試圖查看下游服務器狀態(tài),同時也可以在LoadBalance的時候把無效的服務器給忽略掉。
關于“如何給Ocelot做一個Docker鏡像”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
新聞名稱:如何給Ocelot做一個Docker鏡像
本文網址:http://www.jbt999.com/article40/jsdgeo.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供手機網站建設、企業(yè)建站、小程序開發(fā)、建站公司、商城網站、定制網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)