正 文

自动清理 IIS 日志的脚本


www.7dspace.com  更新日期:2006-1-9 3:38:32  七度空间


原来的虚拟主机服务器一直用 awstats 对 IIS 的日志分析统计,我把它设成每天晚上进行一次分析,统计前一天的日志文件,分析过的日志文件一般也就没有什么大用处了。但是 IIS 的每个站点每天都有一个日志文件生成,小的几百 K,大的则有几百 M,如果不定期及时清理的话,系统盘很快就被塞满了,因此我写了一个清理 IIS 日志的脚本,添加到计划任务里,每天运行一次,自动清除 3 天以前的日志文件,所以服务器不用管它,也不用担心日志塞满系统盘了。

上个月底,重装虚拟主机服务器时,那个自动清理 IIS 日志的脚本没有备份,跟随系统盘一块格式化了。因为一直比较忙,所以重装好以后就没来得及重写,今天登录到那台虚拟主机服务器一看,系统盘空间只剩几百兆了。没办法,只好重新把那个脚本写了一遍。原来好像是用 vbscript 写的,这次改用 javaScript 了。

js代码如下

function dellogfile(beforedays) {
  var fso = new ActiveXObject("Scripting.FileSystemObject");
  var dir = fso.GetFolder("C:\\WINDOWS\\system32\\LogFiles");    //改成你的 IIS 日志目录
  for (var fc = new Enumerator(dir.SubFolders); !fc.atEnd(); fc.moveNext()) {
      if (fc.item().name.substr(0,5) == "W3SVC") {
          for (var logfiles = new Enumerator(fc.item().Files); !logfiles.atEnd(); logfiles.moveNext()) {
              var fileName = logfiles.item().name;
              var year = "20" + fileName.substr(2, 2);
              var mouth = fileName.substr(4, 2);
              var day = fileName.substr(6, 2);
              var days = Math.round(((new Date()).getTime() - Date.UTC(year, mouth - 1, day)) / 1000 / 60 / 60 / 24);
              if (days >= beforedays) logfiles.item().Delete();
           }
      }
   }
}

dellogfile(3);

重写了一遍也没花多少时间,早知如此,我就不拖到今天了。


上一篇:在 WPS 2005 里面插入公式
下一篇:IIS 6 配置备份与迁移
作者:andot  来源:CoolCode.CN ( 责任编辑:7dspace )
收藏此页】【打印】【关闭
站 内 搜 索
 

热 点 导 读
特 别 推 荐