急求……数据库连接池问题,访问人多了,连接池满。。

zhjinzhao 2009-11-07 08:19:24
急求……数据库连接池问题,访问人多了,连接池满。。我已经显示的关闭了所有的con。但是总是连接池满。
...全文
842 29 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
29 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
[Quote=引用 27 楼 zhjinzhao 的回复:]
引用 26 楼 ljb0502 的回复:
不是一段代码的问题  是整个站的问题  尤其是reader的  你整个项目检索下确定都关了吗?

我现在自己访问这个站,数据库的连接数是1-3个。。。不知道算不算正常?
[/Quote]
经过1上午的优化,目前连接数稳定在0-4个,不知道算正常不,访问量为3台主机。
ljb0502 2009-11-07
  • 打赏
  • 举报
回复
假如同时有10个人访问网站,不代表同时有10个数据库连接,因为数据库连接是使用完就立即关闭的,而且同一时刻并不是所有的用户都需要接数据库

要限制的话也可以,在config或者数据库连接字符串设置MaxPoolSize =10,不过连接池过小而数据库访问频繁的话很容易出现超过最大连接数的异常

但是 肯定的说 你这个是连接打开没关闭的原因 不是别的
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
[Quote=引用 26 楼 ljb0502 的回复:]
不是一段代码的问题  是整个站的问题  尤其是reader的  你整个项目检索下确定都关了吗?
[/Quote]
我现在自己访问这个站,数据库的连接数是1-3个。。。不知道算不算正常?
ljb0502 2009-11-07
  • 打赏
  • 举报
回复
不是一段代码的问题 是整个站的问题 尤其是reader的 你整个项目检索下确定都关了吗?
lcglvgn 2009-11-07
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 zhjinzhao 的回复:]
C# codepublicstatic DataSet Query(string SQLString)
{using (SqlConnection connection=new SqlConnection(connectionString))
{
DataSet ds=new DataSet();//connection.Op?-
[/Quote]
这段代码肯定是没问题的
jenny0810 2009-11-07
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 zhjinzhao 的回复:]
C# codepublicstatic DataSet Query(string SQLString)
{using (SqlConnection connection=new SqlConnection(connectionString))
{
DataSet ds=new DataSet();//connection.Op?-
[/Quote]
try
{
command.Fill(ds, "ds");
command.Dispose();
}加上这句试试
yyz985 2009-11-07
  • 打赏
  • 举报
回复
这段代码没问题,问题在其他地方
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
问题是它为什么涨到100,访问量根本不在那
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
链接数100左右的时候网站就打不开了,连接池小吗?我不太清楚
YiYanXiYin 2009-11-07
  • 打赏
  • 举报
回复
你的数据库连接池的链接数是不是太小了, 看看改过设置没有
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
楼上拿个广告搞什么?
hou476466741 2009-11-07
  • 打赏
  • 举报
回复
上这个网站看看看吧 数据库
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
请看看这段代码有问题吗?
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复

public static DataSet Query(string SQLString)
{
using (SqlConnection connection = new SqlConnection(connectionString))
{
DataSet ds = new DataSet();
//connection.Open();
SqlDataAdapter command = new SqlDataAdapter(SQLString, connection);
try
{
command.Fill(ds, "ds");
}
catch
{
//do something
}
finally
{
if (connection.State != ConnectionState.Closed)
{
connection.Close();
}
}
return ds;
}
}
zcxverygood123456 2009-11-07
  • 打赏
  • 举报
回复
"我已经显示的关闭了所有的con"?
==============================
好好检查一下吧,以前我也遇到过,结果是少关闭了一个。
要有耐心检查。
nosuchtracter 2009-11-07
  • 打赏
  • 举报
回复
查询数据最好用using
应该是有资源没释放
yyz985 2009-11-07
  • 打赏
  • 举报
回复
肯定有没有关闭的地方
用dataset不要用open方法
查找所有Open()方法仔细找找有没有finally
zhjinzhao 2009-11-07
  • 打赏
  • 举报
回复
任务长的话,基本上可以说是每个页面有大概向数据库5、6次的查询,而且是单线程的,一个查完一个查。。。这样算多吗?我也考虑到了datareader,但是我的程序使用的全部是dataset然后从datable转化为List<新闻类>,每次ds返回前都在finally块中做了con.Close().找不到问题所在
YiYanXiYin 2009-11-07
  • 打赏
  • 举报
回复
是不是你的任务处理时间太长, 同时又有很多人来访问这些长任务

想办法减少批处理时间

尽量使用dataset, 少用datareader(要用的话要迅速用完,马上关闭)
ljsheng 2009-11-07
  • 打赏
  • 举报
回复
finally
{
//一定要在这里关 如果你的SQL出了异常。。
conn.Close();

}
加载更多回复(9)

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧