自动清理 IIS 日志的脚本

本文介绍了一种使用JavaScript编写的脚本,该脚本能自动清理IIS服务器上的旧日志文件,避免日志文件占用过多磁盘空间。通过设置计划任务定期运行此脚本,可以有效管理服务器资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载自:http://www.coolcode.cn

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

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

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

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

原创作品,转载请注明出处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值