1、编写nginx日志分割bat脚本文件,脚本内容:
@echo offrem @echo off rem 取1天之前的日期echo wscript.echo dateadd("d",-1,date) >%tmp%mp.vbs for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%mp.vbs') do set y=%%ifor /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%mp.vbs') do set m=%%jfor /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%mp.vbs') do set d=%%kif %m% LSS 9 set m=0%m%if %d% LSS 9 set d=0%d%echo %y%-%m%-%d%rem 设置 Nginx 位于的盘符set NGINX_DRIVER=C:rem 设置 Nginx 的主目录set NGINX_PATH=%NGINX_DRIVER%ginxrem 设置 Nginx 的日志目录set LOG_PATH=%NGINX_PATH%logsrem 移动文件move %LOG_PATH%access.log %LOG_PATH%access_%y%-%m%-%d%.logmove %LOG_PATH%error.log %LOG_PATH%error_%y%-%m%-%d%.logrem 切换到 Nginx 所在的盘符%NGINX_DRIVER%rem 进入 Nginx 的主目录cd %NGINX_PATH%rem 向 nginx 发送 reopen 信号以重新打开日志文件,功能与 Linux 平台中的 kill -USR1 一致rem tell nginx to write new logfilesnginx -s reopenecho on
可能出现的异常:
The system cannot find the path specified.
出现这个问题,一般就是生成的文件目录不正确,使用日期作为文件名,注意查看是否日期处理是否正确。
或者是,目录中带有空格没有权限
c:ginx> nginx -s reloadnginx: [error] OpenEvent("ngx_reload_31796") failed (2: The system cannot find the file specified)
一般nginx服务都是用服务启动的方式,而此时如果运行nginx.exe -s reopen就会出现没有足够权限的异常。可以从服务中,找到nginx,依次操作 我的电脑右键 -> 管理 -> 服务 -> nginx -> 属性 -> 登录 -> 登录身份 -> 此账户 -> 填入administration,再填入密码 。修改完后重启服务再试 nginx -s reload ,一切正常。这样就是以管理员启动服务,记得要重启一下,然后就可以了。
2、配置windows定时任务,每天00点00分00秒执行日志切割