.net - 在Docker文件中安装SQL Express

标签 .net sql-server linux windows docker

我在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 ...
    
  • 按照Docker documentation sample中的描述使用Docker Compose(推荐,推荐)
  • 关于.net - 在Docker文件中安装SQL Express,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61713474/

    相关文章:

    c# - 使用 LINQ 仅从表中获取所需的列以修改和保存记录会出现典型错误

    c# - 等效的隐式运算符 : why are they legal?

    sql - 更新表中的单列

    linux - 为什么这个 shell 管道会退出?

    linux - 通过自己的脚本临时更改 bash 提示符

    linux - 在 postgres 中创建数据库时出错

    java - 在 .Net 和 Java 之间共享数据(非对象)的最快(性能方面)方式

    .net - 具有 NTLM 身份验证和自定义用户和密码的 BizTalk 发送端口

    mysql - 在多个 SQL 语句中使用 Count() 并使用 join 连接它们

    sql - 使用不同数据集的 UNION ORDER BY (T-SQL)