nginx

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > nginx > Nginx日志轮转与定时启动脚本

Nginx日志轮转与定时启动脚本的实现

作者:舞姬之光

本文主要介绍了Nginx日志轮转与定时启动脚本的实现,通过批处理脚本rotate-logs.bat实现日志轮转,使用start-nginx.bat启动和重启Nginx服务,借助Windows任务计划程序每日凌晨自动执行日志轮转,确保Nginx服务正常启动,感兴趣的可以了解一下

Windows 下 Nginx 日志不会自动轮转,长期运行会导致 access.log 和 error.log 文件越来越大,影响排查和磁盘空间。Nginx 本身不提供 Windows 下的日志切割功能,需借助批处理脚本 + Windows 任务计划程序实现日志轮转与服务管理。

日志轮转脚本(rotate-logs.bat)

该脚本将当前日志重命名(按日期),并通知 Nginx 重新打开日志文件(通过发送 nginx -s reopen)。

示例脚本内容(保存为 rotate-logs.bat):

@echo off
setlocal enabledelayedexpansion
set "NGINX_DIR=C:\nginx"
set "LOG_DIR=%NGINX_DIR%\logs"
set "DATESTR=%date:~0,4%%date:~5,2%%date:~8,2%"
if not exist "%LOG_DIR%" exit /b
rem 备份 access.log
if exist "%LOG_DIR%\access.log" (
    move "%LOG_DIR%\access.log" "%LOG_DIR%\access_%DATESTR%.log" >nul
)
rem 备份 error.log
if exist "%LOG_DIR%\error.log" (
    move "%LOG_DIR%\error.log" "%LOG_DIR%\error_%DATESTR%.log" >nul
)
rem 通知 Nginx 重新打开日志(要求 nginx 正在运行)
cd /d "%NGINX_DIR%"
nginx -s reopen 2>nul
echo Log rotated: %DATESTR%

定时启动/重启 Nginx 脚本(start-nginx.bat)

适用于开机未自动启动、或需每日固定时间拉起服务的场景。脚本先尝试停止残留进程,再启动主程序。

示例脚本(start-nginx.bat):

@echo off
set "NGINX_DIR=C:\nginx"
rem 检查并结束旧进程
tasklist /fi "imagename eq nginx.exe" | findstr /i "nginx.exe" >nul
if %errorlevel% equ 0 (
    echo Stopping existing nginx...
    %NGINX_DIR%\nginx.exe -s stop >nul 2>&1
    timeout /t 1 >nul
)
rem 启动 Nginx
echo Starting nginx...
cd /d "%NGINX_DIR%"
start nginx.exe
timeout /t 2 >nul
echo Nginx started.

配置 Windows 任务计划程序

让上述脚本每天凌晨执行日志轮转,并在开机/指定时间启动服务。

补充建议与注意事项

提升稳定性与可维护性的小技巧:

到此这篇关于Nginx日志轮转与定时启动脚本的实现的文章就介绍到这了,更多相关Nginx日志轮转与定时启动脚本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文