AddDbContextPool不适用于Azure SQL的Azure广告身份验证

问题描述

我按照MS文档here来配置Azure sql身份验证的Azure AD托管身份,这涉及调整连接字符串(删除用户名/密码)并将这些代码添加到DbContext的构造函数中:

var conn = (Microsoft.Data.sqlClient.sqlConnection)Database.GetDbConnection();
conn.Accesstoken = (new Microsoft.Azure.Services.AppAuthentication.AzureServicetokenProvider()).GetAccesstokenAsync("https://database.windows.net/").Result;

它与Startup.cs中的标准services.AddDbContext()方法配合使用。但是,一旦我使用services.AddDbContextPool()获得更高的性能,身份验证就会因以下错误而中断:

sqlException:用户”的登录失败。 Microsoft.Data.ProviderBase.DbConnectionPool.CheckPoolBlockingPeriod(Exception e)

这是AddDbContextPool()的已知限制吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)