本篇同步發文在個人Blog: 一袋.NET要扛幾樓?打造容器化的ASP.NET Core網站!系列文章 - (7) 建立商品服務的Api - 5
在CatalogApi專案右鍵=>加入=>Dokcer支援,選擇目標平台Linux,將會在根目錄新增Dockerfile檔案,但這Dokcerfile有一些Bug,因為我的專案目錄設計方式,會讓VS產生錯誤的連結,所以需要再手動修改,變成下方的內容。其內容主要功能是在Docker容器內載入NET Core SDK編譯我們的程式碼,將編譯後的目錄檔案複製到Runtime環境的/app目錄,再用NET Core Runtime執行商品服務的Api系統。
FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /code
EXPOSE 80
COPY . .
RUN dotnet restore
RUN dotnet publish -o /out/ -c Release
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
COPY --from=build /out /app/
WORKDIR /app
ENTRYPOINT ["dotnet", "CatalogApi.dll"]
之前已經在docker-compose.yml加入SQL Server的image,而這次要加上商品服務的Api,如下方的yml。主要的參數包含:
version: "3.4"
networks:
frontend:
backend:
services:
catalog:
build:
context: .\src\Services\CatalogApi
dockerfile: Dockerfile
image: rpgshop/catalog
environment:
- DatabaseServer=mssqlserver
- DatabaseName=CatalogDb
- DatabaseUser=sa
- DatabasePassword=JustTest!
- ExternalCatalogBaseUrl=http://${RPGSHOP_EXTERNAL_DNS_NAME_OR_IP}:7000
container_name: rpgcatalogapi
ports:
- "7000:80"
networks:
- backend
- frontend
depends_on:
- mssqlserver
mssqlserver:
image: "microsoft/mssql-server-linux:latest"
ports:
- "1445:1433"
container_name: rpgmssqlcontainer
environment:
- ACCEPT_EULA=Y
- SA_PASSWORD=JustTest!
networks:
- backend
.env檔是一種環境變數檔,用key=value的方式寫在此檔案,目前我們只需要放一筆資料:
RPGSHOP_EXTERNAL_DNS_NAME_OR_IP=docker.for.win.localhost
這是前述的ExternalCatalogBaseUrl的值會被替換,而docker.for.win.localhost是docker內建在Windows的host。
用cmd在docker-compose.yml所在位置輸入指令:
docker-compose up
執行完後,在瀏覽器輸入http://docker.for.win.localhost:7000/swagger ,將看見容器化的商品服務API,如圖1,且使用try it out都是正常運作。
圖1
這一系列的專案將開在這Github:RPGShopOnContainers,會依照文章的主題進度區分資料夾,有需要的人可自行pull / download~
下一篇將建立一套網站前端,整合商品服務的API作商品呈現。