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

 更新时间:2026年04月20日 10:07:29   作者:舞姬之光  
本文主要介绍了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)。

  • 确保 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实现流量控制的示例代码

    Nginx实现流量控制的示例代码

    本文主要介绍了Nginx实现流量控制的示例代码,可以用来限制用户在给定时间内HTTP请求的数量,保护服务器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-05-05
  • 如何实现安装多个nginx

    如何实现安装多个nginx

    这篇文章主要介绍了如何实现安装多个nginx的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • nginx配置静态文件服务器详解

    nginx配置静态文件服务器详解

    本篇文章主要介绍了nginx配置静态文件服务器详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • nginx服务器搭建和配置详解

    nginx服务器搭建和配置详解

    本篇文章主要介绍了nginx服务器搭建和配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • 分割nginx日志的实现(避免日志多大)

    分割nginx日志的实现(避免日志多大)

    nginx默认没有提供对日志文件的分割功能,所以随着时间的增长,access.log和error.log文件会越来越大,本文主要介绍了分割nginx日志的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • Nginx处理Web请求机制的方法详解

    Nginx处理Web请求机制的方法详解

    这篇文章主要介绍了Nginx处理Web请求机制的方法,通过对worker抢占机制、传统服务器事件处理机制以及Nginx事件处理机制的对比,详细解析Nginx在处理web请求机制时的逻辑,需要的朋友可以参考下
    2025-04-04
  • Nginx中roxy_set_header与add_header区别举例浅析

    Nginx中roxy_set_header与add_header区别举例浅析

    proxy_set_header是一个 Nginx 配置指令,用于设置将要转发到后端服务器的 HTTP 请求头,这篇文章主要给大家介绍了关于Nginx中roxy_set_header与add_header区别的相关资料,需要的朋友可以参考下
    2024-04-04
  • 基于Nginx实现限制某IP短时间访问次数

    基于Nginx实现限制某IP短时间访问次数

    这篇文章主要介绍了基于Nginx实现限制某IP短时间访问次数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-12-12
  • 解决Nginx转发图片不能显示的问题

    解决Nginx转发图片不能显示的问题

    在使用Nginx作为反向代理将iServer的HTTP协议转换为HTTPS协议时,可能会遇到静态资源无法加载、页面跳转回HTTP协议、访问服务管理界面权限问题等情况,本文给大家介绍解决Nginx转发图片不能显示的问题,感兴趣的朋友一起看看吧
    2024-11-11
  • Nginx作为反向代理时传递客户端IP的设置方法

    Nginx作为反向代理时传递客户端IP的设置方法

    因为nginx的优越性,现在越来越多的用户在生产环境中使用nginx作为前端,不管nginx在前端是做负载均衡还是只做简单的反向代理,都需要把日志转发到后端real server,以方便我们检查程序的各种故障
    2014-08-08

最新评论