Log4j每天、每小时、每分钟定时生成日志文件

日志管理与定时生成策略
本文介绍如何通过Log4j实现日志的定时生成,包括添加必要的jar文件、Web.xml配置、log4j.properties编写及日志Bean的实现,以达到方便存储和查看的效果。

              在做项目中基本上都用到了日志log,那么自然就会遇到问题,比方说,日志太大了怎么办?日志很乱怎么办?

这时我们就会想到如果能够把日志分为定时的生成即:Log4j每天、每小时、每分钟定时生成日志文件这样多好,既可以方便存储亦利于查看。针对这个一想法,本人做了下测试,发现效果还是可以的,特把代码以及配置贴出以便初学者参考:

一、首先添加必须的jar文件,如:commons-logging.jar、log4j.jar等这些,这个就不说了;

二、Web.xml配置:

<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>

一定要加上这个监听,测试过好几遍,如果不加上此监听,那么无法定时把Log中的数据存储到文件中,即:定时生成日志文件;

三、log4j.properties文件编写: 

下面为此次关键的部分

#LogFile Write
log4j.logger.logcase= INFO, dufLog
log4j.appender.dufLog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.dufLog.File=${webapp.root}WEB-INF/logfiles/logcase/logcase
log4j.appender.dufLog.DatePattern = '_'yyyy-MM-dd-HH-mm'.log'
log4j.appender.dufLog.MaxFileSize=10MB
log4j.appender.dufLog.layout=org.apache.log4j.PatternLayout
log4j.appender.dufLog.layout.ConversionPattern=%d%n%m%n

其中logcase为所需要产生日志的bean中所定义的;一般来说,一个项目中有很多种日志,即:每种日志生成不同的文件,如:有服务启动日志,有bug处理日志.....为了不让所有的日志在一起混合,所以就需要自定义日志来针对不同的功能模块;

上面${webapp.root}默认表示项目的根目录,整句表示日志文件将处于目录:WEB-INF/logfiles/logcase/logcase;

DatePattern中配置的'_'yyyy-MM-dd-HH-mm'.log' 意思是根据这个时间来定时生成文件,并且把'_'yyyy-MM-dd-HH-mm'.log'附加在原文件的后面,即:logcase_'yyyy-MM-dd-HH-mm'.log', 由于定义到mm所以就每分钟生成一次。


四、Log产生Bean<这里使用Struts2来测试>;


这里的自定义Log标识:logcase就必须要与log4j.properties中的相对应,


好,上面的配置已经完成,启动服务、运行次Action中的方法,即可记录日志信息,如下图所示:



<think>好的,我现在需要帮助用户解决如何设置一个每两分钟执行一次BAT文件,并记录日志的问题。首先,我要回顾用户之前的对话历史,确保理解他的需求。用户之前提到过删除路由和添加永久路由的问题,但现在的问题是关于任务计划和日志记录,所以需要转换思路。 用户的需求很明确:通过任务计划或批处理命令实现每两分钟运行一次BAT文件,并记录执行过程到日志中。我需要考虑两种方法:使用Windows任务计划程序,或者编写自循环的批处理脚本。同时,用户希望生成日志,这涉及到如何将输出重定向到文件。 首先,任务计划程序是更可靠的方法,因为它由系统管理,不容易出错。用户可能担心任务的稳定性,特别是如果BAT文件需要长时间运行的话。任务计划程序可以设置触发器,每两分钟触发一次,但需要确认系统是否允许这么短的间隔。Windows任务计划的最小间隔是一分钟,所以两分钟是可以的,但用户可能需要设置重复任务,持续时间设置为无限。 然后,关于日志记录,用户需要在BAT文件中使用输出重定向,例如使用`>>`将标准输出和错误输出追加到日志文件。可能需要考虑日志文件的大小,是否需要定期清理,但用户暂时没有提到这一点,暂时先提供基本的方法。 另一种方法是自循环的批处理脚本,但这可能会有资源占用和稳定性问题。例如,脚本中使用`timeout`命令等待两分钟,然后再次执行,但这种方法如果脚本意外终止,任务就会停止。不过用户可能希望不依赖任务计划程序,所以需要给出两种方案。 接下来,我需要参考用户提供的引用内容。引用1提到了schtasks命令创建计划任务,每分钟运行一次。引用3是关于批量执行任务的BAT文件。用户的需求和引用3类似,但需要定时执行和记录日志。需要结合这些信息,给出具体的命令示例。 在安全方面,用户可能不希望任务以管理员权限运行,除非必要。需要提醒用户注意权限问题,特别是如果BAT文件需要修改系统设置或访问受限资源的话。同时,日志路径应该选择用户有写入权限的位置,比如用户目录或特定日志文件夹。 还要考虑任务的开始时间和结束时间。用户可能希望任务持续运行,直到手动停止,因此在schtasks命令中,可能需要设置开始期和结束期为长期有效,或者留空。同时,/mo参数指定重复间隔,这里是两分钟,所以参数应该是2。 另外,用户提到生成日志记录,可能需要将每次执行的期时间也记录下来,方便后续排查问题。可以在BAT文件开头添加`echo %date% %time%`命令,将当前时间写入日志。 最后,需要验证这些步骤是否正确。例如,创建任务后,手动触发一次,检查日志是否生成,内容是否正确。同时,检查任务计划程序库中任务的状态,确保没有错误发生。 总结步骤: 1. 编写BAT文件,包含需要执行的任务,并添加输出重定向到日志文件。 2. 使用schtasks命令创建计划任务,设置每两分钟触发一次,执行BAT文件。 3. 或者编写自循环的BAT脚本,但需提醒用户可能的稳定性问题。 4. 提供日志查看和任务管理的建议,如使用`notepad log.txt`查看日志,或使用任务计划程序管理任务。 可能的问题:用户可能不知道如何以管理员权限运行命令,需要提醒在运行schtasks时可能需要管理员权限。此外,如果BAT文件本身有错误,日志中可能无法捕获,建议在BAT文件中加入错误处理,比如使用`||`运算符记录错误信息。 需要确保schtasks命令的语法正确,特别是路径中的空格需要用引号括起来。例如,如果BAT文件路径包含空格,必须使用双引号包围路径。 最后,考虑到用户可能希望日志按时间分割,但用户没有特别要求,暂时提供基本的追加日志方法。如果需要更复杂的日志管理,可以建议使用日志轮换工具或脚本,但这可能超出当前问题的范围。</think>根据您的需求,结合Windows任务计划程序与批处理技术,提供以下两种实现方案: ### 一、任务计划程序方案(推荐) #### 1. 创建日志增强型批处理脚本 新建`task_logger.bat`,添加以下内容: ```bat @echo off set LOGFILE=C:\TaskLogs\%date:~0,4%%date:~5,2%%date:~8,2%.log :: 时间戳记录 echo [%date% %time%] 任务开始执行 >> %LOGFILE% :: 核心任务内容(此处替换为您的实际命令) your_command.exe 2>&1 >> %LOGFILE% :: 错误代码检测 if %errorlevel% neq 0 ( echo [ERROR] 执行失败,错误代码:%errorlevel% >> %LOGFILE% ) else ( echo [SUCCESS] 执行完成 >> %LOGFILE% ) ``` #### 2. 创建计划任务命令 以管理员身份运行CMD执行: ```powershell schtasks /create /tn "两分钟任务" /tr "C:\path\to\task_logger.bat" /sc minute /mo 2 /ru SYSTEM /rl HIGHEST /f ``` - `/ru SYSTEM`:以系统账户运行,避免权限问题[^1] - `/rl HIGHEST`:确保任务最高优先级执行 - `/mo 2`:每2分钟重复执行 - 任务配置存储在注册表`HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks` #### 3. 验证任务状态 ```powershell # 查看任务详情 Get-ScheduledTask -TaskName "两分钟任务" | Get-ScheduledTaskInfo # 实时监控日志 Get-Content C:\TaskLogs\*.log -Wait ``` ### 二、自循环批处理方案(备选) ```bat @echo off :loop call "实际任务.bat" >> "C:\CyclicLogs\%time:~0,2%%time:~3,2%.log" 2>&1 timeout /t 120 /nobreak >nul goto loop ``` - 特点:不依赖任务计划服务,但需要保持CMD窗口常开 - 日志文件小时分钟命名(如1532.log) ### 三、高级日志管理技巧 1. **日志轮转控制** ```bat forfiles /p "C:\TaskLogs" /s /m *.log /d -7 /c "cmd /c del @path" ``` - 自动删除7天前的日志文件 2. **日志压缩存档** ```powershell # 每天0点压缩日志 schtasks /create /tn "日志压缩" /tr "powershell Compress-Archive -Path C:\TaskLogs\*.log -DestinationPath C:\Archives\%date%.zip" /sc DAILY /st 00:00 ``` ### 四、方案对比表 | 特性 | 任务计划方案 | 自循环方案 | |--------------------|------------------------------|--------------------------| | 可靠性 | 系统级守护进程 | 依赖CMD窗口保持开启 | | 资源占用 | 低(由任务计划服务托管) | 持续占用终端进程 | | 日志管理 | 支持自动分割文件 | 需手动实现文件分割 | | 故障恢复 | 系统自动重启失败任务 | 进程终止即停止 | | 适用场景 | 生产环境/长期运行任务 | 临时测试/短周期任务 | ### 五、注意事项 1. 若使用网络路径,需添加`net use`持久化连接: ```bat net use Z: \\server\share /persistent:yes ``` 2. 遇到`ERROR 0x41303`任务挂起时,执行: ```powershell Get-ScheduledTask -TaskName "两分钟任务" | Start-ScheduledTask ``` 3. 推荐使用UTF-8编码保存BAT文件: ```bat chcp 65001 >nul ``` [^1]: 系统账户具有最高权限,但需注意文件访问权限设置 [^2]: 计划任务历史记录存储在`C:\Windows\System32\Tasks`目录 [^3]: 使用`2>&1`可将标准错误输出重定向到日志文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值