我在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
但这不起作用。
最佳答案
简而言之,您不能在主dockerfile中添加另一个FROM
来安装Sql Server,因为这会在临时镜像中创建新层并删除其所有先前层。
因此,您有两种选择:
apt-get
命令在docker文件的最后一层中使用RUN
命令安装Sql Server(不推荐):sudo apt-get install mssql-server=(version_number)
// and many more startup configurations ...
关于.net - 在Docker文件中安装SQL Express,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61713474/