首先接到这个任务,发现nginx的日志限制更多的都是在Linux下做的,找了半天,也没找到能直接通过nginx.conf更改体现到日志限制上的。

  最后决定直接通过bat脚本,来对nginx的日志进行分割和删除。

  至于需要谁来执行bat脚本,大家可以根据自己的业务需求来操作,比如:

  1.通过系统的任务计划程序

  2.通过java程序系统定时器

  先来说第一种:

       

  

   

通过创建计划任务,然后选中要执行的bat脚本,设置执行周期,就可以搞定。

  第二种:通过服务器内的java程序,定时器调用

 1 package com.gosun.check.config.task;
2
3 import lombok.extern.slf4j.Slf4j;
4 import org.springframework.scheduling.annotation.Scheduled;
5 import org.springframework.stereotype.Component;
6
7 import java.io.BufferedReader;
8 import java.io.File;
9 import java.io.InputStream;
10 import java.io.InputStreamReader;
11
12 @Slf4j
13 @Component
14 public class PartitionDelLogTask {
15
16 @Scheduled(cron = "0 1 0 * * ?") //每天23点执行
17 public void delNginxLogTask(){
18 log.info("===开始执行定时任务===");
19 String relativelyPath=System.getProperty("user.dir");
20 String batPath = relativelyPath+"\\fenge.bat";
21 try {
22 File batFile = new File(batPath);
23 boolean batFileExist = batFile.exists();
24 log.info(">>>> 是否找到bat:{};文件位置:{}",batFileExist,batPath);
25 if (batFileExist) {
26 callCmd(batPath);
27 }
28 log.info(">>>> bat文件执行成功");
29 } catch (Exception e) {
30 log.error(">>>> bat文件执行失败:{}", e.getMessage());
31 }
32 }
33
34 private static void callCmd(String locationCmd){
35 StringBuilder sb = new StringBuilder();
36 try {
37 Process child = Runtime.getRuntime().exec(locationCmd);
38 InputStream in = child.getInputStream();
39 BufferedReader bufferedReader=new BufferedReader(new InputStreamReader(in));
40 String line;
41 while((line=bufferedReader.readLine())!=null)
42 {
43 sb.append(line + "\n");
44 }
45 in.close();
46 try {
47 child.waitFor();
48 } catch (InterruptedException e) {
49 log.info("------异常---------{}",e.getMessage());
50 }
51 System.out.println("sb:" + sb.toString());
52 log.info("------执行完成---------");
53 } catch (Exception e) {
54 log.info(e.getMessage());
55 }
56 }
57 }

则bat脚本:

 1 @shift
2
3 ::设置nginx安装文件路径和当天时间变量
4 @echo off
5 set nginx_dir=D:\nginx
6 set dir=%nginx_dir%\logs\cut_log
7 set log=%nginx_dir%\logs\access.log
8 set errorlog=%nginx_dir%\logs\error.log
9 set mqttlog=%nginx_dir%\logs\access_mqtt.log
10 set today=%date:~0,4%-%date:~5,2%-%date:~8,2%
11 set nginxStart = D:\nginx\nginx.exe
12
13 ::判断nginx的cut_log目录
14 :check_dir
15 @echo off
16 if exist %dir% (
17 goto main
18 ) else (
19 md "%dir%"
20 goto main
21 )
22
23 ::创建相关目录和对nginx日志进行切割
24 :main
25 @echo off
26 ::结束nginx进程
27 taskkill /F /IM nginx.exe > nul
28 move "%log%" "%dir%\access-%today%.log" > nul
29 move "%errorlog%" "%dir%\error-%today%.log" > nul
30
31 if exist %mqttlog% (
32 move "%mqttlog%" "%dir%\access_mqtt-%today%.log" > nul
33 ) else (
34 @echo "no mqttLog"
35 )
36
37 ::删除指定天数之前的文件
38 forfiles /p "d:\nginx\logs\cut_log" /s /m *.* /d -7 /c "cmd /c del @path"
39 ::删除文件大于10M的
40 for /r d:\nginx\logs\cut_log %%i in (*.log) do @(if %%~zi gtr 10240000 del "%%i" /f)
41 set dirr=/d d:/nginx
42 echo "%dirr%"
43 echo. start Nginx......
44 cd "%dirr%"
45 IF EXIST "%dirr%nginx.exe" (
46 echo "start '' nginx.exe"
47 start nginx.exe
48 )
49 echo.OK

bat脚本思路是:

  先停止nginx进程 --> 把access.log和error.log剪切到cut_log文件夹中 --> 根据文件创建时间删除7天前的文件 --> 删除文件大于10M的 --> 启动nginx程序

  在这里有个小提醒,在切换盘符到nginx文件夹,启动Nginx的时候,在本地IDEA跑程序测试,是没问题,但把程序放到服务器上,就执行不完全,也没报错,通过排查,找到是脚本的错误,然后才找到cd d:,实际并没有切换到d:,最后换成的 cd /d d:,这样才没问题,或者直接d: ,太久没写windows的脚本了,都有点忘了,哈哈哈!

WINDOWS下对NIGNX日志文件进行限制的更多相关文章

  1. windows下自动删除过期文件的脚本

    windows下自动删除过期文件的脚本 前言: 比如日志文件每天都产生,时间长了就会有很大的一堆垃圾.整理一下 定时删除文件的方法. 正文: Windows: 定时删除tomcat日志和缓存.可以保留 ...

  2. syslog之三:建立Windows下面的syslog日志服务器

    目录: <syslog之一:Linux syslog日志系统详解> <syslog之二:syslog协议及rsyslog服务全解析> <syslog之三:建立Window ...

  3. windows下编辑过的文件在Linux下用vi打开行尾会多出一个^M符号

    一般情况下,windows下编辑过的文件在Linux下用vi打开行尾会多出一个^M符号,如下图: 这是因为Windows等操作系统用的文本换行符和UNIX/Linux操作系统用的不同,Windows系 ...

  4. 如何查看linux系统下的各种日志文件 linux 系统日志的分析大全

    日志分类: 1. 连接时间的日志 连接时间日志一般由/var/log/wtmp和/var/run/utmp这两个文件记录,不过这 两个文件无法直接cat查看,并且该文件由系统自动更新,可以通过如下: ...

  5. Linux下查看alert日志文件的两种方法

    --linux下查看alert日志文件的两种方法: --方法1: SQL> show parameter background_dump_dest; NAME TYPE VALUE ------ ...

  6. Python Windows下打包成exe文件

    Python Windows 下打包成exe文件,使用PyInstaller 软件环境: 1.OS:Win10 64 位 2.Python 3.7 3.安装PyInstaller 先检查是否已安装Py ...

  7. windows下快速修改host文件

    windows下快速修改host文件 win+r  输入 notepad c:\Windows\System32\drivers\etc\hosts

  8. 【Linux】windows下编写的脚本文件,放到Linux中无法识别格式

    注意:我启动的时候遇到脚本错误 » sh startup.sh -m standalone tanghuang@bogon : command not found : command not foun ...

  9. windows下右键新建md文件

    windows下右键新建md文件 打开注册表 win键+R打开运行对话框, 输入regedit, 打开注册表编辑器. 修改注册表 在磁盘的任意位置新建一个文件, 后缀名为reg, 并写入一下内容 [H ...

  10. windows下tomcat切割日志按照日期输出

    windows下tomcat默认不会把应用的日志信息输出在日志文件中的,只会在控制台打印. 解决方法: 1,下载工具cronolog-1.6.1-win32.zip,并解压. 2,把cronolog. ...

随机推荐

  1. 引擎之旅 Chapter.1 高分辨率时钟

    目录 游戏中的时间线 真实时间线 游戏时间线 全局时钟的实现方式 我们如何理解时间.在现实生活中,时间就是一个有方向的直线.从一个无穷远到另一个无穷远.用数学去抽象地思考,它就是一个从无穷小到无穷大的 ...

  2. MySQL InnoDB缓存

    1. 背景 对于各种用户数据.索引数据等各种数据都是需要持久化存储到磁盘,然后以"页"为单位进行读写. 相对于直接读写缓存,磁盘IO的成本相当高昂. 对于读取的页面数据,并不是使用 ...

  3. 深度剖析Istio共享代理新模式Ambient Mesh

    摘要:今年9月份,Istio社区宣布Ambient Mesh开源,由此引发国内外众多开发者的热烈讨论. 本文分享自华为云社区<深度剖析!Istio共享代理新模式Ambient Mesh>, ...

  4. Beats:使用Elastic Stack监控RabbitMQ

  5. Kubernetes 中部署 MySQL 集群

    文章转载自:https://www.cnblogs.com/ludongguoa/p/15319861.html 一般情况下 Kubernetes 可以通过 ReplicaSet 以一个 Pod 模板 ...

  6. 分布式ID详解(5种分布式ID生成方案)

    分布式架构会涉及到分布式全局唯一ID的生成,今天我就来详解分布式全局唯一ID,以及分布式全局唯一ID的实现方案@mikechen 什么是分布式系统唯一ID 在复杂分布式系统中,往往需要对大量的数据和消 ...

  7. typora基础和计算机五大组成部分

    typora typora软件 ​ 是一款适合于IT行业文本编辑器,笔记,当下来说,非常火爆,可以使用多种语言,python java... ​ 安装的时候路径选择可以设置一些简单便于后续查找的文件路 ...

  8. 【前端必会】tapable、hook,webpack的灵魂

    背景 什么是tapable.hook,平时做vue开发时的webpack 配置一直都没弄懂,你也有这种情况吗? 还是看源码,闲来无聊又看一下webpack的源码,看看能否找到一些宝藏 tapable和 ...

  9. HTML基础知识(1)常用标签的使用 h、p、img、meta、a、iframe...

    文章目录 1.html简介 2.html注释 3.标签的属性 3.1 代码 3.2 测试结果 4.常用的标签 4.1 代码 4.2 测试结果 5.实体 5.1 代码 5.2 测试结果 6.图片引入 6 ...

  10. 制作一个windows垃圾清理小程序

    制作一个windows垃圾清理小程序: 把下列代码保存为.bat文件(如垃圾清理.bat) 双击它就能很快地清理垃圾文件,大约一分钟不到. 就是下面的文字(这行不用复制)=============== ...