很多时候是由于网站空间服务器的配置
或者资源限制导致的不足以承受运行的情况
有些是买的时候
不知道有所限制
而不能满足程序的运营需求
最好是联系服务商查阅相关日志
对症下药
如果撑不住最好换机器
-----------------------------------------
出现这种情况是由于您的网站超过了系统资源限制(CPU或者IIS)造成的,
这个现象在WINDOWS2003+IIS6的环境下都会出现,主要是程序占用资源太多。
不同的程序占用的资源都不一样,这个跟程序设计的合理性和优化程度有关;
另外,一些死循环程序,或者不优化的程序都会占用太多的系统资源,而系统资源明显是有限的。
如果一个网站的程序占资源太多或者发生太多的错误,系统日志就会提示:“应用程序池
'User_pooll'
被自动禁用,原因是为此应用程序池提供服务的进程中出现一系列错误,
或者提示:应用程序池
'User_pooll'
超过了其作业限制设置。
有关更多信息,请参阅微软官方
http://go.microsoft.com/fwlink/events.asp
的帮助和支持中心。
这时,访问这个网站就会提示:Service
Unavailable。
一般系统会在30秒左右恢复正常,多刷新几次就能正常访问了。但是这个时间恢复后因为访问量太大在极短的时间网站又不能上了。
另外,如果网站当前访问人数过多,超过了系统的iis连接数(或CPU峰值)限制,也会出现Service
Unavailable的提示(win2k主机下出现连接过多就会提示:连接过多,请稍后再试;而win2003的主机刚直接提示:Service
Unavailable)如果经常出现类似的错误,请及时优化网站程序,或者升级你的主机至更高的款型,以获得更多的系统资源。
网站超CPU的四种可能原因:
一.网站攻击
二.程序设计不合理,资源占用高,或本身在做占资源的 *** 作,如采集
三.访问量过大
四.有搜索蜘蛛收录
程序占用资源太多的原因:
有一个或多个ACCESS数据库在多次读写过程中损坏,微软的MDAC系统在写入这个损坏的ACCESS文件时,ASP线程处于BLOCK状态,结果其他线程只能等待,IIS被死锁了,全部的CPU时间都消耗在DLLHOST(ASP进程)中。
参考解决办法:
压缩和修复我的数据库
下载数据库文件--[如果是.asp的扩展名,请改为.mdb的扩展名]--用ACCESS打开--选择工具--数据库实用工具--压缩和修复数据库--[改回.asp的扩展名]--上传覆盖原来数据库文件
注册了不良的Com组件,特别是用VB开发的ACTIVE
X控件,可能导致占用内存使用量不断增长
参考解决办法:尽量减少或避免非官方或是客户要求的不必要的组件
多媒体等文件下载占用服务器带宽
参考解决办法:停止下载
程序问题
需要及时的关闭不再使用的数据库,以避免一直占用服务器资源
在conn.asp
连接数据库字符串语句中加入如下
sub
endConnection()
conn.close
set
conn=nothing
end
sub
其它程序问题:把IE选项里
显示友好HTTP错误信息
的勾取消掉,再访问网站看出现什么错误信息,然后再调试
上传重要的数据库等文件更新,由于正处于受访问状态,可能导致瞬间占用率上升
一般此情况较少,若有出现此情况时,可能有必要先暂停站点,再作更新
ACCESS论坛(如动W)大了以后就很容易出现数据库方面的问题,当你的论坛数据库在30M以上,帖子5万左右,可能就会出现数据库吃不消的情况
建议取消程序中使用的on
error
resume
next这个容错语句,对错误进行调试。
临时解决办法:定期删除多余的数据、压缩数据库,限制论坛灌水,甚至限制论坛注册。如果是ASP论坛,可以使用分表储存功能,会有较好的效果
比较长远办法:更换论坛和数据库,一般都采用商业版本+MSSQL
的方案来解决
出现这种情况是由于网站超过了iis限制造成的。
由于2003的 *** 作系统在提示IIS过多时并非像2000系统提示“链接人数过多”,而是提示"Service Unavailable",出现这种情况是由于网站超过了系统资源限制造成的,主要是程序占用资源太多,通过设置应用程序池把账户改为NetworkService即可解决。
解决办法如下:
1、在windows系统中,打开开始菜单,搜索iis,并打开。
2、打开iis管理后,在最右侧找到 *** 作栏,点击打开查看应用程序池。
3、进入应用程序池后,点击选择defaultapppool。
4、点击选中后,在右边的 *** 作栏中,点击打开高级设置。
5、进入到高级设置后,下翻滚动找到进程模型里面的标识。
6、找到标识后,点击后面的选项框。
7、点击后,d出应用程序标识池,在内置账户中选择NetworkService,点击确定后,即可解决。
数据库吃内存。根据查询相关资料信息显示,在读取效率上,从内存中读取数据肯定比从硬盘中读取数据要快。从写入效率上来看,当内存比较大的时候,我们需要往硬盘中写数据的时候,就不用每次都写,可以先缓存着,攒够了再一次性写入(延缓写入)。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)