Nginx日志轮转与定时启动脚本的实现
Windows 下 Nginx 日志不会自动轮转,长期运行会导致 access.log 和 error.log 文件越来越大,影响排查和磁盘空间。Nginx 本身不提供 Windows 下的日志切割功能,需借助批处理脚本 + Windows 任务计划程序实现日志轮转与服务管理。
日志轮转脚本(rotate-logs.bat)
该脚本将当前日志重命名(按日期),并通知 Nginx 重新打开日志文件(通过发送 nginx -s reopen)。
- 确保 Nginx 已以 Windows 服务方式安装(如用 nginx-service.exe 或 NSSM),否则 -s reopen 可能失败
- 脚本需在 Nginx 安装目录下运行(或修改路径为绝对路径),例如:C:\nginx
- 使用 %date:~0,4%%date:~5,2%%date:~8,2% 获取格式化日期(如 20240615),适配大多数系统区域设置
示例脚本内容(保存为 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)
适用于开机未自动启动、或需每日固定时间拉起服务的场景。脚本先尝试停止残留进程,再启动主程序。
- 避免重复启动多个 nginx 实例(检查 tasklist 中是否存在 nginx.exe)
- 若使用 Windows 服务方式部署,建议直接用 net start nginx 替代手动启动
- 启动后可加短暂停顿(timeout /t 2 >nul),再检查端口(如 80)是否监听,增强健壮性
示例脚本(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 任务计划程序
让上述脚本每天凌晨执行日志轮转,并在开机/指定时间启动服务。
- 打开“任务计划程序”,创建基本任务 → 设置名称、触发器(如“每天”“02:00”)、操作(启动程序 → 选择 .bat 文件)
- 在“常规”选项卡中勾选“不管用户是否登录都要运行”和“不存储密码”(需改用本地系统账户或配置凭据)
- 若脚本涉及服务控制(如 net start),务必勾选“使用最高权限运行”
- 测试任务:右键任务 → “运行”,观察日志目录是否生成新文件、Nginx 是否响应正常
补充建议与注意事项
提升稳定性与可维护性的小技巧:
- 在 nginx.conf 的 http 或 server 块中,可添加 log_format 自定义日志结构,便于后续分析
- 轮转脚本中可加入日志保留天数逻辑(如用 forfiles 删除 30 天前的旧日志)
- 避免将日志写入系统盘根目录;建议将 logs 目录映射到其他磁盘分区
- 首次部署后,手动运行一次脚本确认路径、权限、nginx 状态均正常,再交由计划任务托管
到此这篇关于Nginx日志轮转与定时启动脚本的实现的文章就介绍到这了,更多相关Nginx日志轮转与定时启动脚本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Nginx中roxy_set_header与add_header区别举例浅析
proxy_set_header是一个 Nginx 配置指令,用于设置将要转发到后端服务器的 HTTP 请求头,这篇文章主要给大家介绍了关于Nginx中roxy_set_header与add_header区别的相关资料,需要的朋友可以参考下2024-04-04


最新评论