当多个用户访问同一页面时,我在ASP.NET 4网站上收到以下错误消息:
底层提供商未能打开。在 System.Data.EntityClient.EntityConnection.OpenStoreConnectionIf 等......
我使用Entity Framework 4访问SQL Server 2008数据库。
页面有时有效,所以我知道连接字符串是正确的。此外,数据库设置为多用户,并且我在连接字符串中将MARS设置为true。
同样在事件查看器中,我有时会收到SQL Server消息:
服务器将断开连接,因为客户端驱动程序具有 在会话处于单用户模式时发送了多个请求。
正如我所说,只有当我尝试通过刷新页面或点击同一链接在两台不同的机器上同时访问同一页面时,才会发生这种情况。
非常感谢任何帮助。
添加了连接字符串(第一个用于ASPNETDB,第二个用于主数据库):
<add name="ApplicationServices" connectionString="Data Source=MyServer;Initial Catalog=MyDB;Integrated Security=False;Persist Security Info=False;User ID=****;Password=****;Connect Timeout=120" />
<add name="MyDBEntities" connectionString="metadata=res://*/App_Code.MyDBModel.csdl|res://*/App_Code.MyDBModel.ssdl|res://*/App_Code.MyDBModel.msl;provider=System.Data.SqlClient;provider connection string="Data Source=MyServer;Initial Catalog=MyDB;Integrated Security=False;User ID=****;Password=****;Connect Timeout=120;User Instance=false;MultipleActiveResultSets=True"" providerName="System.Data.EntityClient" />
我用来访问上下文的类如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using MyDBModel;
using System.Web.Security;
/// <summary>
/// Summary description for MyDataAccess
/// </summary>
public static class MyDataAccess
{
// Private Class Members
//-----------------------------------------------------------------------------------------
private static MyDBModel.MyDBEntities dal = new MyDBModel.MyDBEntities();
// Class Constructor / Destructor
//-----------------------------------------------------------------------------------------
static MyDataAccess()
{
// Set Entity ObjectContext Merge Options - this basically ensures database items aren't cached
dal.NEWS.MergeOption = System.Data.Objects.MergeOption.OverwriteChanges;
dal.NEWS_IMAGES.MergeOption = System.Data.Objects.MergeOption.OverwriteChanges;
}
// Public Methods for Data Access
//-----------------------------------------------------------------------------------------
/// <summary>
/// Get All Current News Items
/// </summary>
public static List<NEWS> GetCurrentNewsItems()
{
var items = from news in dal.NEWS
where news.NEWS_ACTIVE == true &&
news.NEWS_STARTDATE <= DateTime.Today &&
news.NEWS_EXPIRYDATE >= DateTime.Today
orderby news.NEWS_DATE descending
select news;
return NewsManager.GetMyNewsItems(items).ToList();
}
}
然后在我的.aspx.cs页面中,我会使用类似的东西:
var news = MyDataAccess.GetCurrentNewsItems();
答案 0 :(得分:6)
我认为您的问题是由将ObjectContext对象存储在静态变量中引起的。
的msdn文档ObjectContext类不是线程安全的。数据的完整性 在多线程中无法确保ObjectContext中的对象 场景。