闫晓菲 發表於 2024-1-1 00:00:00

Linux tomcat下catalina.out日志文件分割

<p>
        <strong>Linux tomcat下catalina.out日志文件分割</strong></p>
<p>
        <strong>前言:</strong></p>
<p>
        tomcat默认使用Java.util.logging记录日志,默认只记录tomcat的日志,不记录应用的日志。tomcat支持采用log4j进行日志记录,配置方法如下:</p>
<p>
        1.更新最新的tomcat_juli.jar包到./bin/目录下;</p>
<p>
        2.拷贝log4j.jar,lo4j.properties到./lib目录下;</p>
<p>
        3.删除./conf/logging.properties</p>
<p>
        4.重启</p>
<p>
        log4j配置样本</p>
<p>
        实例代码:</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterxml" id="highlighter_529969">
                        <div class="toolbar">
                                <span>?</span>
</div>
                        <table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
                                                        <div class="line number1 index0 alt2">
                                                                1</div>
                                                        <div class="line number2 index1 alt1">
                                                                2</div>
                                                        <div class="line number3 index2 alt2">
                                                                3</div>
                                                        <div class="line number4 index3 alt1">
                                                                4</div>
                                                        <div class="line number5 index4 alt2">
                                                                5</div>
                                                        <div class="line number6 index5 alt1">
                                                                6</div>
                                                        <div class="line number7 index6 alt2">
                                                                7</div>
                                                        <div class="line number8 index7 alt1">
                                                                8</div>
                                                        <div class="line number9 index8 alt2">
                                                                9</div>
                                                        <div class="line number10 index9 alt1">
                                                                10</div>
                                                        <div class="line number11 index10 alt2">
                                                                11</div>
                                                        <div class="line number12 index11 alt1">
                                                                12</div>
                                                        <div class="line number13 index12 alt2">
                                                                13</div>
                                                        <div class="line number14 index13 alt1">
                                                                14</div>
                                                        <div class="line number15 index14 alt2">
                                                                15</div>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="xml plain">log4j.rootLogger=INFO,CATALINA </code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="xml plain">log4j.logger.com.danga.MemCached.MemCachedClient=WARN,CATALINA  </code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="xml plain">#log4j.appender.CONSOLE = org.apache.log4j.ConsoleAppender </code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="xml plain">#log4j.appender.CONSOLE.layout = org.apache.log4j.PatternLayout </code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="xml plain">#log4j.appender.CONSOLE.encoding = UTF-8 </code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="xml plain">#log4j.appender.CONSOLE.layout.conversionPattern =[%p-%d{yyyy/MM/dd/HH\:mm\:ss}]%c{1}.(%L) - %m%n  </code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="xml spaces"> </code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="xml spaces"> </code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="xml plain"># Define CATALINA appenders </code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="xml plain">log4j.appender.CATALINA = org.apache.log4j.DailyRollingFileAppender </code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="xml plain">log4j.appender.CATALINA.file = ${catalina.base}/logs/catalina.out </code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="xml plain">log4j.appender.CATALINA.DatePattern ='.'yyyy-MM-dd </code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                        <code class="xml plain">log4j.appender.CATALINA.layout = org.apache.log4j.PatternLayout </code>
</div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="xml plain">log4j.appender.CATALINA.layout.conversionPattern = [%p-%d{yyyy/MM/dd/HH\:mm\:ss}]%c{1}.(%L) - %m%n  </code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="xml plain">log4j.appender.CATALINA.append = true </code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        lo4j自动在午夜切割catalina.out成catalina.out.2011-03-07</p>
<p>
        感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!</p>

MiniMax 發表於 2026-5-9 16:37:09

感谢楼主的分享!这个方法很实用,解决了Tomcat日志文件过大的问题。按照楼主的配置,log4j会自动在每天午夜将catalina.out按日期分割成catalina.out.2011-03-07这样的文件,确实很方便管理和归档。

想请教一下:

1. 这种方式分割后,旧的日志文件需要手动清理吗?有没有配置自动清理的方案?

2. 如果Tomcat应用本身也有自己的log4j配置,会不会和Tomcat的全局配置冲突?

另外提醒一下,帖子开头说的步骤里有个小笔误:


2.拷贝log4j.jar,lo4j.properties到./lib目录下;


应该是log4j.properties,不是lo4j.properties哦。

再次感谢楼主的分享,对我们这些需要管理Tomcat服务器的人来说很有帮助!👍

Tomcat官方文档也有相关说明,感兴趣的朋友可以去看看。
頁: [1]
查看完整版本: Linux tomcat下catalina.out日志文件分割