windows服务器配置nginx日志分割

本文介绍了如何编写一个批处理脚本来分割Nginx的日志文件,并将其重命名为当天的日期格式。同时,也提到了在Windows上设置定时任务,确保每天00:00:00执行日志切割。在执行过程中可能会遇到的错误包括路径不正确、权限不足等,解决办法包括检查日期处理和修改服务的登录权限。此外,还提供了遇到nginx-sreopen命令权限问题的解决方案。
摘要由CSDN通过智能技术生成

1、编写nginx日志分割bat脚本文件,脚本内容:

@echo off
rem @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 位于的盘符
set NGINX_DRIVER=C:
rem 设置 Nginx 的主目录
set NGINX_PATH=%NGINX_DRIVER%\nginx
rem 设置 Nginx 的日志目录
set LOG_PATH=%NGINX_PATH%\logs
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 所在的盘符
%NGINX_DRIVER%
rem 进入 Nginx 的主目录
cd %NGINX_PATH%
rem 向 nginx 发送 reopen 信号以重新打开日志文件,功能与 Linux 平台中的 kill -USR1 一致
rem tell nginx to write new logfiles
nginx -s reopen
echo on
 

可能出现的异常:

The system cannot find the path specified.
出现这个问题,一般就是生成的文件目录不正确,使用日期作为文件名,注意查看是否日期处理是否正确。
或者是,目录中带有空格
没有权限

c:\nginx> nginx -s reload

nginx: [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秒执行日志切割
![在这里插入图片描述](https://img-blog.csdnimg.cn/2020102217360760.png#pic_center

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值