• tomcat的catalina.out日志文件过大


    今天发现一个服务器的/opt目录数据过大,最后发现是tomcat中的catalina.out日志过大引起的

    用du命令查看opt下一层的数据文件大小
    [root@ccssapportalp opt]# du -h --max-depth=1 /opt

    最终发现在tomcat里catalina.out的文件很大
    [root@ccssapportalp logs]# ll -h /opt/liferay6.2ce/tomcat-7.0.42/logs/catalina.out
    -rw-r--r-- 1 root root 12G Oct 22 16:40 catalina.out

    清空这个日志文件
    [root@ccssapportalp logs]# cat /dev/null> catalina.out
    ---------------------

    Tomcat默认生成的日志文件catalina.out,随着时间的推移,逐渐增大,可能达到G数量级。文件过大,我们将无法使用过常规编辑工具查看,严重影响系统维护工作。解决此问题,主要从Tomcat和代码两方面考虑。

    一、 代码本身考虑
    Tomcat输出catalina.out文件,数据主要来源为:System.out 和 System.err 在控制台上直接输出的信息。为了减少日志输出的压力,规范代码习惯,编码时应避免使用System.out.println()和e.printStackTrace()。

    二、 Tomcat配置考虑

    1、 Tomcat使用log4j
    我们知道,tomcat默认使用Java.util.logging进行日志打印,并且Linux默认都将应用日志打印在catalina.out。当系统长期运行,我们就会发现问题:catalina.out日志量越来越大,对我们查看和管理都极其不便。(默认tomcat的catalina日志不支持每天一个文件那种配置)
    解决以上问题有几种思路,网上讨论得较多的就是日志切割,如通过cronolog工具进行日切。这种方式治标不治本,不够灵活。我们web项目通常都会使用log4j进行日志打印,并且log4j本身就支持按日(按月/按小时/按分钟等)打印日志,还有丰富的配置,只需要对tomcat配置稍加修改即可实现。
    1)准备jar包:
    log4j-1.2.17.jar(下载)
    tomcat-juli.jar,tomcat-juli-adapters.jar (下载,根据你的Tomcat版本选择对应的分支)
    2)将上面的三个jar包拷贝到 Tomcat 的 lib 目录下;将 tomcat-juli.jar 再拷贝到 Tomcat 的bin 目录下,替换原有的jar包;
    3)修改 Tomcat 的 conf/context.xml文件,将<Context>改为<Context swallowOutput="true">,可以减少控制台日志的输出
    (增加swallowOutput="true" 的属性配置,只有这样才能完全的把tomcat的stdout给接管过来。这一步很关键在官网及网上找了许多资料都没有提及。);
    4)删除 Tomcat 的 conf/logging.properties文件(或者重命名-建议);
    5)把工程中的log4j.properties 文件拷贝到在 Tomcat 的 lib 目录下;
    6)重启tomcat

    2、 Tomcat配置
    部署服务时,修改Tomcat的conf/context.xml文件,将<Context>改为<Context swallowOutput="true">;
    3、 使用cronolog工具分割 (cronolog的使用)
    A、 cronolog工具下载
    官方URL:http://cronolog.org/download/index.html
    B、 cronolog编译安装
    [TSP@tsp-dev-webservice ~]$ tar xvf cronolog-1.6.2.tar.gz
    [TSP@tsp-dev-webservice cronolog-1.6.2]$ ./configure
    [TSP@tsp-dev-webservice cronolog-1.6.2]$ make
    [TSP@tsp-dev-webservice cronolog-1.6.2]$ sudo make install
    C、 修改Tomcat启动脚本catalina.sh
    a、 修改输出日志路径
    修改:
    if [ -z "$CATALINA_OUT" ] ; then
    CATALINA_OUT="$CATALINA_BASE"/logs/catalina.out
    fi
    为:
    if [ -z "$CATALINA_OUT" ] ; then
    CATALINA_OUT="$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out
    fi
    b、 删除生成日志文件
    注释:
    touch "$CATALINA_OUT"
       为:
    #touch "$CATALINA_OUT"
    c、 修改启动脚本参数
    修改:
    org.apache.catalina.startup.Bootstrap "$@" start
    >> "$CATALINA_OUT" 2>&1 "&"
        为:
    org.apache.catalina.startup.Bootstrap "$@" start 2>&1
    | /usr/local/sbin/cronolog "$CATALINA_OUT" >> /dev/null &
    D、 重启Tomcat
    Tomcat输出日志文件分割成功,输出log文件格式为:catalina.2014-08-15.out类型。

  • 相关阅读:
    iOS中几种定时器
    开发基于Handoff的App(Swift)
    [react ] TextArea 光标定位到最后
    图片上传 配合客户端做出效果展示
    ["1", "2", "3"].map(parseInt)
    react 微信公众号 cnpm start 启动页面报path错误解决
    在家办公这点事
    【转】关于请求时 options 相关问题
    cnpm i 遇到报错
    react + antd Menu 点击菜单,收起其他展开的所有菜单
  • 原文地址:https://www.cnblogs.com/maohuidong/p/9796840.html
Copyright © 2020-2023  润新知