httperr 占用大量系统空间的解决方法
c:\win2003\system32\logfiles\httperr 文件夹下有许多的小文件 一个正好是 1024kb 文件名是httperr****.log 这样格式的文件。
在iis 6.0中,记录日志的功能已经改为由http.sys实现,http.sys在内核模式下运行。这一改进加快了日志写入速度,同时避免了多个工作进程争用同一日志文件。某些特殊的情况下,http.sys会遇到错误,这时它应该但却不能将日志信息写入web网站的日志,例如,工作进程正在被回收,禁止http.sys处理用户请求,或者用户试图连接到服务器,但请求中只提供了iis所需信息的一部分。如果出现这类情况,http.sys将把事件写入一个新的日志文件httperr.log。
在排解故障、优化iis 6.0的过程中,httperr.log日志文件是十分重要的。默认情况下,httperr.log文件保存在\system32\logfiles目录。在httperr.log日志文件中可以找到的信息包括:所有的503(服务不可用)错误,空闲连接超时,解析url时出现的各种错误,最后10个提交给失败的应用程序池的请求。
iis 6.0还拥有一种称为二进制日志的功能,启用这个功能后,iis 6.0将把web网站的所有日志信息写入一个二进制格式的日志文件,日志文件的扩展名是.ibl。要启用二进制日志功能,只要把配置文件的w3svcc/centralbinaryloggingenabled条目设置成ture(1)即可。对于isp来说,这个功能应该非常有用。isp的每台机器上可能有1000甚至更多的web网站,如果每个web网站每天生成一个日志文件,日志文件的总数很快会达到一个天文数字。微软最近发布的log parser 2.0工具能够读取二进制日志文件并生成报告,这个工具可以从http://download.microsoft.com/download/iis50/utility/2.0/nt5xp/en-us/setup.exe下载。log parser 2.0还能够读取前面介绍的httperr.log文件并生成报告。
解决方案
如果您检查 c:\windows\system32\logfiles\httperr\httperr*.log 文件在父 sus 服务器, 您会将可能看到 timer_minbytespersecond 错误或 timer_connectionidle 错误。 这些是由 iis 默认设置, 内其元数据库, 定义用于连接到保持活动小通信流速率和最大空闲时间之前连接中断允许。
1) 从 iis 管理器右键单击 internet information server (iis) 管理器级别根目录上并转到属性。 选中要启用直接编辑元数据库框。 单击确定。
在记事本中打开 c:\windows\system32\inetsrv\metabase.xml 文件 2)。 要搜索有关 " minfilebytespersec "。 将用于 minfilebytespersec 设置从 240 更改为 0。 执行其他搜索, 该时间将 600 " connectiontimeout "。 保存更改并退出。
3) 重新启动 iisadmin 服务以更改生效。
一、关闭iis httprerr日志功能
默认情况下,2003服务器会把所有iis访问错误的记录写入 c:\windows\system32\logfiles\httperr 下的 log 文件中,如果访问量比较大,可能一段时间后 日志文件可能会占满c盘空间,导致服务器死机
同时因为要写入所有的iis访问记录,如果访问量较大会大大增加服务器cpu占用率
关闭httperr的方法
运行里输入 regedit 进入注册表编辑器
[hkey_local_machine\system\currentcontrolset\services\http\parameters]
在右边 点鼠标右键 新建dword值 enableerrorlogging 重新启动服务器就可以了
"enableerrorlogging"=dword:00000000
重起后,2003不再写入httperr日志文件,可以看到服务器cpu占用明显下降!
二、修改存储目录也不失为一个好的办法
寻找:
hkey_local_machine\system\currentcontrolset\services\http\parameters
在下面建立一个字符串值.即reg_sz
数值名称 命名为: errorloggingdir
数值数据 为你指定的路径 比如 d:\logofilse