解决out of memory in asp.net

问题1:为什么aspnet_wp.exe没有自动restart,当out of memory发生的时候

回答:服务器内存为2G,而machine.config中的memorylimit为60(60%, 1.2G)超过了一个进程可以使用的最大地址空间,也就是说,当out of memory发生的时候,内存为1G,尚未达到上限,所以,没有自动recycle

问题2:如何确定是asp.net发生out of memory的?

回答:参考微软文档http://msdn.microsoft.com/library/en-us/dnbda/html/dbgch02.asp

跟踪若干perfermance counter的变化,尤其是,当out of memory发生时

问题3:如何确定出问题的页面?

跟踪perfermance counter,采样频率为1秒,做出一段时间的memory状态log,然后对照event log中的,找出发生out of memory时刻的内存变化情况。另一方面,将这段时间的IIS log导入到数据库,以便查询分析,两者互相对照,找出导致内存疯长的页面,然后进行code review.

这次的原因在于,网页中频繁对一个表进行增加,更新操作,由于数据库相应速度下降,导致页面不能及时释放dataset.

其他的发现:

1. dataset很大的时候,不能直接使用datagrid的分页机制,而应该使用DbDataAdapter中的

Fill(DataSet,int,int,string)填充需要显示的一页数据

2. 使用SqlHelper和上述fill,就没有必要使用dataReader,dataReader比较危险,非常容易忘记关闭

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值