Tomcat日志

1 Tomcat 日志概述

Tomcat 日志分为下面5类:

  1. catalina:Cataline引擎的日志文件,文件名catalina.日期.log
  2. localhost:Tomcat下内部代码丢出的日志,文件名localhost.日期.log
  3. manager:Tomcat下默认管理应用日志,文件名manager.日期.log
  4. host-manager:虚拟主机方面
    (1~4 以上默认开启的,都可以在日志目录下的 </span>catalina/conf/logging.properties.: < / s p a n > c a t a l i n a / c o n f / l o g g i n g . p r o p e r t i e s 文 件 中 编 辑 . 注 : <script type="math/tex" id="MathJax-Element-1">{catalina}/conf/logging.properties 文件中编辑 . 注 :</script>{catalina} 是 tomcat 的安装目录)
  5. Access:访问日志(默认关闭,需要到配置文件中的${catalina}/conf/server.xml中配置)

每类日志的级别分为如下 7 种:
    SEVERE (highest value) > WARNING > INFO > CONFIG > FINE > FINER > FINEST (lowest value) ;
     ALL:所有日志均输出; OFF:禁用日志输出.

2 Tomcat 日志配置

2.1 catalina localhost manager host-manager的日志的配置

一般情况下无需配置,在 </span>catalina/conf/logging.properties.<em>:<span> < / s p a n > c a t a l i n a / c o n f / l o g g i n g . p r o p e r t i e s 文 件 中 编 辑 . < e m > 注 :< s p a n > <script type="math/tex" id="MathJax-Element-2">{catalina}/conf/logging.properties 文件中编辑 . 注 :</script>{catalina} 是 tomcat 的安装目录)
例如catalina的配置:可以修改 日志级别、路径、前缀

1catalina.org.apache.juli.AsyncFileHandler.level = FINE
1catalina.org.apache.juli.AsyncFileHandler.directory = ${catalina.base}/logs
1catalina.org.apache.juli.AsyncFileHandler.prefix = catalina.
    
    
  • 1
  • 2
  • 3

注 :${catalina.base}是每个Tomcat目录私有信息的位置,就是conf、logs、temp、webapps和work的父目录。

2.2 访问日志Access的配置

默认 tomcat 不记录访问日志,如下方法可以使 tomcat 记录访问日志

编辑 </span>catalina/conf/server.xml.<em>: < / s p a n > c a t a l i n a / c o n f / s e r v e r . x m l 文 件 . < e m > 注 : <script type="math/tex" id="MathJax-Element-3">{catalina}/conf/server.xml 文件 . 注 :</script>{catalina} 是 tomcat 的安装目录

把以下的注释去掉即可。

 <!--
        <Valve className="org.apache.catalina.valves.AccessLogValve"
         directory="logs"  prefix="localhost_access_log." suffix=".txt"
         pattern="common" resolveHosts="false"/>
  -->
     
     
  • 1
  • 2
  • 3
  • 4
  • 5

参数说明:

参数名解释
className官方文档上说了:This MUST be set to org.apache.catalina.valves.AccessLogValve to use the default access log valve。
directory日志文件存放的目录。通常设置为tomcat下已有的那个logs文件。
prefix日志文件的名称前缀。
suffix日志文件的名称后缀。
pattern最主要的参数。下面会细讲。
resolveHosts默认false,直接写服务器IP地址啦,如果是true,tomcat会将这个服务器IP地址通过DNS转换为主机名;
rotatable默认为true,tomcat生成的文件名为prefix(前缀).时间(一般是按天算).suffix(后缀),如:localhost_access_log.2018-09-22.txt。设置为false的话,tomcat会忽略时间,不会生成新文件,文件名就是:localhost_access_log.txt。长此以往,这个日志文件会超级大
condition这个参数不太实用,可设置任何值,比如设置成condition=”tkq”,那么只有当ServletRequest.getAttribute(“tkq”)为空的时候,该条日志才会被记录下来。
fileDateFormat顾名思义,就是时间格式嘛。但这个时间格式是针对日志文件名起作用的。咱们生成的日志文件全名:localhost_access_log.2016-09-22.txt,这里面的2016-09-22就是这么来的。如果想让tomcat每小时生成一个日志文件,也很简单,将这个值设置为:fileDateFormat=”yyyy-MM-dd.HH”,当然也可以按分钟生成什么的,自己改改吧^_^
pattern

该项值可以为: common 与 combined ,这两个 预 先 设 置好的 格式对应的日志输出内容如下:
自由组合,例如
common 的值: %h %l %u %t %r %s %b
combined 的值: %h %l %u %t %r %s %b %{Referer}i %{User-Agent}i

参数名解释
%a远端IP地址
%A本地IP地址
%b发送的字节数,不包括HTTP头,如果为0,使用”-”
%B发送的字节数,不包括HTTP头
%h远端主机名(如果resolveHost=false,远端的IP地址)
%H请求协议
%l(小写的L)- 从identd返回的远端逻辑用户名(总是返回 ‘-‘)
%m请求的方法(GET,POST,等)
%p收到请求的本地端口号
%q查询字符串(如果存在,以 ‘?’开始)
%r请求的第一行,包含了请求的方法和URI
%s响应的状态码
%S用户的session ID
%t日志和时间,使用通常的Log格式
%u认证以后的远端用户(如果存在的话,否则为’-‘)
%U请求的URI路径
%v本地服务器的名称
%D处理请求的时间,以毫秒为单位
%T处理请求的时间,以秒为单位
另外还可以将cookie, 客户端请求中带的HTTP头(incoming header), 会话(session)或是ServletRequest中的数据都写到Tomcat的访问日志中,你可以用下面的语法来引用。如下
%{xxx}c记录特定的cookie xxx
%{xxx}o记录响应头xxx(Http Resonse)
%{xxx}i记录客户端请求中带的HTTP头xxx(incoming headers) ,例如:%{Referer}i从哪个页面链接跳转到的此页面,%{User-agent}:i用户的User-Agent
%{xxx}s记录HttpSession中的xxx属性(attribute)。
%{xxx}r记录ServletRequest中的xxx属性(attribute),xxx是我们自定义的参数名,需要在request中设置这个值request.setAttribute
配置获取POST参数

    上面提到的%r参数能打印出请求的url和get参数。如果url指定访问方式是post,post的参数是打印不出来的。当需要打印post参数,该怎么办?———使用%{xxx}r
例如配置%{postdata}r,因为postdata使我们自定义的参数名。所以需要在request中设置这个值。下面附上设置postdata到request中的代码。

import java.io.IOException;
import java.util.Enumeration;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public final class PostDataDumperFilter implements Filter {

    Logger logger = LoggerFactory.getLogger(getClass());

    private FilterConfig filterConfig = null;

    public void destroy() {
        this.filterConfig = null;
    }

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        if (filterConfig == null)
            return;

        Enumeration<String> names = request.getParameterNames();
        StringBuilder output = new StringBuilder();
        while (names.hasMoreElements()) {
            String name = (String) names.nextElement();
            output.append(name).append("=");
            String values[] = request.getParameterValues(name);
            for (int i = 0; i < values.length; i++) {
                if (i > 0) {
                    output.append("' ");
                }

                output.append(values[i]);
            }
            if (names.hasMoreElements())
                output.append("&");
        }
        request.setAttribute("postdata", output);
        logger.debug("postdata: " + output);
        chain.doFilter(request, response);
    }

    public void init(FilterConfig filterConfig) throws ServletException {
        this.filterConfig = filterConfig;
    }
}
     
     
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53

如果觉得Tomcat的日志不够好,也可以让 apache tomcat 使用 log4j 管理日志,而且有时候还能更清楚的知道为什么有些应用启动不成功,日志可以查的很清楚。

        <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/markdown_views-ea0013b516.css">
            </div>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值