如何解决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 举报,一经查实,本站将立刻删除。