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是作为一个反向代理,转发,和负载均衡的服务器,也可以用于分布式,下面这篇文章主要给大家介绍了关于Nginx如何配置根据路径转发的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • nginx部署vue页面白屏或刷新404问题解决

    nginx部署vue页面白屏或刷新404问题解决

    最近部署vue项目后发现刷新页面会404,本文就来介绍一下nginx部署vue页面白屏或刷新404问题解决,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • PHP开发框架kohana3.3.1在nginx下的伪静态设置例子

    PHP开发框架kohana3.3.1在nginx下的伪静态设置例子

    这篇文章主要介绍了PHP开发框架kohana3.3.1在nginx下的伪静态设置例子,kohana曾经是codeigniter框架的衍生版,后来发展成另一个独立的PHP5开发框架,需要的朋友可以参考下
    2014-07-07
  • nginx做代理转发前端请求到后端的代码示例

    nginx做代理转发前端请求到后端的代码示例

    Nginx作为反向代理服务器,可以有效处理请求并转发到后端服务器,这篇文章主要介绍了nginx做代理转发前端请求到后端的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-01-01
  • Nginx添加lua模块的实现方法

    Nginx添加lua模块的实现方法

    这篇文章主要介绍了Nginx添加lua模块的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • nginx限制IP恶意调用短信接口处理方法

    nginx限制IP恶意调用短信接口处理方法

    这篇文章主要介绍了nginx限制IP恶意调用短信接口处理方法,一种是nginx黑名单方式,另一种是限制IP请求数。需要的朋友可以参考下
    2018-06-06
  • 详解nginx请求头数据读取流程

    详解nginx请求头数据读取流程

    这篇文章主要介绍了详解nginx请求头数据读取流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Nginx中proxy_pass的斜杠的两种方式

    Nginx中proxy_pass的斜杠的两种方式

    Nginx的官方文档将proxy_pass分为不带URI和带URI两种类型,本文就来介绍Nginx中proxy_pass的斜杠的两种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-10-10
  • nginx如何实现同个ip、端口访问不同的项目(以路径区分项目)

    nginx如何实现同个ip、端口访问不同的项目(以路径区分项目)

    这篇文章主要介绍了nginx如何实现同个ip、端口访问不同的项目(以路径区分项目),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • nginx 关闭默认站点的方法

    nginx 关闭默认站点的方法

    国内机房一般都要求网站主关闭空主机头,防止未备案的域名指向过来造成麻烦
    2012-09-09

最新评论