问题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比较危险,非常容易忘记关闭