在单独的 Docker 容器中使用数据库时添加迁移会引发错误

Pio*_*rek 4 asp.net entity-framework entity-framework-core .net-core asp.net-core

我已经使用自动生成的身份设置创建了 dockerized ASP.net Core 应用程序(所以我已经有了默认的实体框架配置)。我已将 SQL Server 创建为单独的容器,这是我的docker-compose.yml

version: '3.4'

services:
    blazorapp1:
        image: blazorapp1
        build:
            context: .
            dockerfile: Dockerfile
        depends_on: 
            - db

    db:
        image: "mcr.microsoft.com/mssql/server"
        environment:
            SA_PASSWORD: "[SOMEPASSWORD]"
            ACCEPT_EULA: "Y"

Run Code Online (Sandbox Code Playgroud)

我已经测试了数据库配置:当 Visual Studio 为我生成身份设置时,我可以成功创建新用户,并且它们已正确存储在内存中。

然后我想创建新的数据库表:

public class ApplicationDbContext : IdentityDbContext
{

    public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
        : base(options)
    {
    }

    public virtual DbSet<WeightLog> WeightLogs { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

为了应用这些更改,我Add-Migration WeightLogger在包管理器控制台中使用过。

这是一个输出:

PM> Add-Migration WeightLogger
Build started...
Build succeeded.
An error occurred while accessing the Microsoft.Extensions.Hosting services. Continuing without the application service provider. Error: C:\root\.nuget\packages\microsoft.aspnetcore.identity.ui\3.1.1\staticwebassets\V4\
Unable to create an object of type 'ApplicationDbContext'. For the different patterns supported at design time, see https://go.microsoft.com/fwlink/?linkid=851728
Run Code Online (Sandbox Code Playgroud)

这里有几件事我不明白。第一个错误指出我C:\root\.nuget\packages\microsoft.aspnetcore.identity.ui\3.1.1\staticwebassets\V4\不存在。然后有第二个错误告诉我ApplicationDbContext无法创建。链接指向我的网页,它告诉我:

创建新的 ASP.NET Core 应用程序时,默认情况下包含此挂钩。

那么,这是否意味着我不需要配置任何东西?为什么它不工作呢?使用 Docker 容器作为环境时,我应该以不同的方式创建迁移吗?

Mar*_*ouk 5

我遇到了完全相同的问题,最终通过从 Visual Studio 中删除 docker-compose 项目来解决它,只保留 docker-compose.yaml 并通过命令行管理它并解决它。

对于那些不想删除解决方案的 docker-compose 支持并面临相同问题的人,我认为可以通过为上下文实现设计时接口或使用docker ef migrations add命令来解决它,但在所有情况下,它都是应该向 Microsoft 报告的问题。