簡體   English   中英

在 docker 文件中安裝 SQL Express

[英]Install SQL Express in docker file

我在 Visual Studio 中有以下 docker 文件:

FROM mcr.microsoft.com/dotnet/core/aspnet:3.1 AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443
EXPOSE 1433

FROM mcr.microsoft.com/dotnet/core/sdk:3.1 AS build
WORKDIR /src
COPY ["src", ""]
COPY ["NuGet.Config", ""]
COPY ["test", "test"]
COPY ["*.sln", ""]

#RUN dotnet restore --configfile NuGet.Config  "Security.WebApi/Security.WebApi.csproj"
COPY . .
WORKDIR "/src/src/WebApi.WebApi"
RUN dotnet build "WebApi.WebApi.csproj" -c Release -o /app/build

#### Run all tests in sln   ####
WORKDIR /src
RUN dotnet test "HSB.Webapi.sln" "--logger:trx"
WORKDIR "/src/src/Webapi.WebApi"
#### END OF TESTS ####

FROM build AS publish
RUN dotnet publish "Webapi.WebApi.csproj" -c Release -o /app/publish

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "Webapi.WebApi.dll"]

這給了我一個容器,我可以在其中構建和運行我的 .NET 應用程序。

但是,現在我也想安裝 SQL Express。 如何在上面的 docker 文件中執行此操作? 我想在容器啟動時安裝並啟動 sql express。

我試圖添加這個:

FROM microsoft/mssql-server-linux:latest
COPY ./create-db.sql .
ENV ACCEPT_EULA Y
ENV sa_password fisk1234
ENV MSSQL_TCP_PORT=1433
CMD /opt/mssql/bin/sqlservr

但這行不通。

簡而言之,您不能將另一個FROM添加到您的主 dockerfile 以安裝 Sql 服務器,因為這會在臨時映像中創建新層並刪除其所有以前的層。

所以你有兩個選擇:

  1. 使用RUN命令在 docker 文件的最后一層使用apt-get命令安裝 Sql 服務器(不推薦):

     sudo apt-get install mssql-server=(version_number) // and many more startup configurations...
  2. 使用 Docker 按照Docker 文檔示例中的描述進行編寫(直接和推薦

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM