windows下nginx日志分割

  1. 云栖社区>
  2. 博客>
  3. 正文

windows下nginx日志分割

技术小胖子 2017-11-17 13:18:00 浏览732
展开阅读全文

在nginx根目录,创建cut-logs.bat

@echo off
rem 取1天之前的日期
echo wscript.echo dateadd("d",-1,date) >%tmp%\tmp.vbs
for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%\tmp.vbs') do set y=%%i
for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%\tmp.vbs') do set m=%%j
for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%\tmp.vbs') do set d=%%k
if %m% LSS 9 set m=0%m%
if %d% LSS 9 set d=0%d%
echo %y%-%m%-%d%

rem 查看系统正在运行的nginx进程
tasklist /fi "imagename eq nginx.exe"
或
::taskkill /F /IM nginx.exe > nul  该行是注释

rem设置Nginx 位于的盘符
set NGINX_DRIVER=D:

rem 设置 Nginx 的主目录
::set NGINX_PATH=%NGINX_DRIVER%\nginx  该行是注释
set NGINX_PATH="%NGINX_DRIVER%\Program Files\nginx"

rem 设置 Nginx 的日志目录
set LOG_PATH=%NGINX_PATH%\logs

rem 保留30天日志
set save_days=30

rem 切换到 Nginx 所在的盘符
%NGINX_DRIVER%

rem 切换到logs所在目录
cd %LOG_PATH%

rem 移动文件
move %LOG_PATH%\access.log %LOG_PATH%\access_%y%-%m%-%d%.log
move %LOG_PATH%\error.log %LOG_PATH%\error_%y%-%m%-%d%.log

rem 进入 Nginx 的主目录
cd %NGINX_PATH%

rem向nginx 发送 reopen 信号以重新打开日志文件,功能与 Linux 平台中的 kill -USR1 一致
nginx -s reopen

rem 删除30天前日志
forfiles /p "%LOGS_PATH%" /s /m *%y%-%m%-%d%.log /d -%save_days% /c "cmd /c del @path"
echo on

注:OpenEvent("Global\ngx_reopen_5452") failed (5: Access is denied)
根据这个提示我分析了一下,应该是权限问题,这时我分别用服务启动和命令启动nginx后发现
服务启动后 nginx 是以system 身份运行的,而命令启动后 nginx 是以admin(administrator) 管理员身份运行的
这样看问题应该是出在了服务的运行身份上,所以我们应该修改服务的运行身份,具体修改方法:
服务--》nginx service--》属性--》登陆--》登陆身份--》选择此账户后账户填入admin,再填入密码
windows下nginx日志分割
windows下nginx日志分割
windows下nginx日志分割




      本文转自ling118 51CTO博客,原文链接:http://blog.51cto.com/meiling/2048314,如需转载请自行联系原作者




网友评论

登录后评论
0/500
评论
技术小胖子
+ 关注