精华内容
下载资源
问答
  • Tomcat查看Log日志

    2020-08-05 20:43:46
    为了方便调试,我们在Java Web程序中往往会设置一些日志记录语句(如 ...2.Log文件夹内有许多名字格式为“catalina.2020-08-05”的txt文件,双击打开对应日期的文件,就能看到对应的Log日志了。 3.日志查看示例: ...

    为了方便调试,我们在Java Web程序中往往会设置一些日志记录语句(如 Logger.getLogger())等,当我们使用Tomcat挂载Java Web程序时,就需要在Tomcat的文件夹下去查看这些日志,以便对代码做出修改,具体查看方式如下:
    1.进入Tomcat文件夹下的Log目录;
    2.Log文件夹内有许多名字格式为“catalina.2020-08-05”的txt文件,双击打开对应日期的文件,就能看到对应的Log日志了。
    3.日志查看示例:
    效果图示例
    ——————————————————————————
    最后贴一下我的个人公众号:微信搜索“茶迁”或扫描下图。平时会更新一些编程相关的文章,欢迎大家关注~
    茶迁

    展开全文
  • tomcat的gclog日志进行分析,进行可视化展示,可以查看一些配置参数,检查是否软件是否运行正常
  • 以前spring项目是扔到tomcat里面去部署的,我们可以直接去tomcat放access日志的地方查看,现在springboot项目,tomcat是内嵌到框架里面的,这时候我们就需要在项目的配置文件application.yml里面来配置tomcat日志...

            昨天遇到的一个问题是,我有一个接口,这个接口会接收一个100M的视频,然后我想知道,这个接口的处理时间。以前spring项目是扔到tomcat里面去部署的,我们可以直接去tomcat放access日志的地方查看,现在springboot项目,tomcat是内嵌到框架里面的,这时候我们就需要在项目的配置文件application.yml里面来配置tomcat的日志了。以下是基本的配置

    server:
      tomcat:
          accesslog:
            enabled: true
            directory: D:/logs/tw-weiting
            rotate: true
            pattern: '%t %a %A %m %U%q %s %D %I %B'
            buffered: false

    enabled:是否打印accesslog,默认是false

    directory:放access日志的路径

    rotate:指定是否启用日志轮转。默认为true。这个参数决定是否需要切换切换日志文件,如果被设置为false,则日志文件不会切换,即所有文件打到同一个日志文件中,并且file-date-format参数也会被忽略

    pattern:定义access日志的格式,可以自定义,也可以用Access log内置了两个日志格式模板,

    • 【pattern:common】  - %h %l %u %t "%r" %s %b,依次为:远程主机名称,远程用户名,被认证的远程用户,日期和时间,请求的第一行,response code,发送的字节数
    • 【pattern:combined 】- %h %l %u %t "%r" %s %b "%{Referer}i" "%{User-Agent}i",依次为:远程主机名称,远程用户名,被认证的远程用户,日期和时间,请求的第一行,response code,发送的字节数,request header的Referer信息,request header的User-Agent信息。

    除了内置的模板,我们常用的配置有:

    • %t %a "%r" %s (%D ms),日期和时间,请求来自的IP(不一定是原始IP),请求第一行,response code,响应时间(毫秒),样例:[21/Mar/2017:00:06:40 +0800] 127.0.0.1 POST /bgc/syncJudgeResult HTTP/1.0 200 63,这里请求来自IP就是经过本机的nginx转发的。
    • %t [%I] %{X-Forwarded-For}i %a %r %s (%D ms),日期和时间,线程名,原始IP,请求来自的IP(不一定是原始IP),请求第一行,response code,响应时间(毫秒),样例:[21/Apr/2017:00:24:40 +0800][http-nio-7001-exec-4] 10.125.15.1 127.0.0.1 POST /bgc/syncJudgeResult HTTP/1.0 200 5,这里的第一个IP是Nginx配置了X-Forwarded-For记录了原始IP。这里简要介绍下上面用到的HTTP请求头X-Forwarded-For,它是一个 HTTP 扩展头部,用来表示 HTTP 请求端真实 IP,其格式为:X-Forwarded-For: client, proxy1, proxy2,其中的值通过一个逗号+空格把多个IP地址区分开,最左边(client)是最原始客户端的IP地址,代理服务器每成功收到一个请求,就把请求来源IP地址添加到右边。

    pattern的配置: 

    • %a - Remote IP address,远程ip地址,注意不一定是原始ip地址,中间可能经过nginx等的转发
    • %A - Local IP address,本地ip
    • %b - Bytes sent, excluding HTTP headers, or '-' if no bytes were sent
    • %B - Bytes sent, excluding HTTP headers
    • %h - Remote host name (or IP address if enableLookups for the connector is false),远程主机名称(如果resolveHosts为false则展示IP)
    • %H - Request protocol,请求协议
    • %l - Remote logical username from identd (always returns '-')
    • %m - Request method,请求方法(GET,POST)
    • %p - Local port,接受请求的本地端口
    • %q - Query string (prepended with a '?' if it exists, otherwise an empty string
    • %r - First line of the request,HTTP请求的第一行(包括请求方法,请求的URI)
    • %s - HTTP status code of the response,HTTP的响应代码,如:200,404
    • %S - User session ID
    • %t - Date and time, in Common Log Format format,日期和时间,Common Log Format格式
    • %u - Remote user that was authenticated
    • %U - Requested URL path
    • %v - Local server name
    • %D - Time taken to process the request, in millis,处理请求的时间,单位毫秒
    • %T - Time taken to process the request, in seconds,处理请求的时间,单位秒
    • %I - current Request thread name (can compare later with stacktraces),当前请求的线程名,可以和打印的log对比查找问题

    Access log 也支持将cookie、header、session或者其他在ServletRequest中的对象信息打印到日志中,其配置遵循Apache配置的格式({xxx}指值的名称):

    • %{xxx}i for incoming headers,request header信息
    • %{xxx}o for outgoing response headers,response header信息
    • %{xxx}c for a specific cookie
    • %{xxx}r xxx is an attribute in the ServletRequest
    • %{xxx}s xxx is an attribute in the HttpSession
    • %{xxx}t xxx is an enhanced SimpleDateFormat pattern (see Configuration Reference document for details on supported time patterns)

     其他配置参考:

    server.tomcat.accesslog.buffered=true # 缓冲输出,使其只定期刷新。
    server.tomcat.accesslog.directory=logs # Directory in which log files are created. Can be relative to the tomcat base dir or absolute.
    server.tomcat.accesslog.enabled=false # Enable access log.
    server.tomcat.accesslog.file-date-format=.yyyy-MM-dd # 要放在日志文件名中的日期格式。rotate为false的时候,这个也就不生效了。
    server.tomcat.accesslog.pattern=common # Format pattern for access logs.
    server.tomcat.accesslog.prefix=access_log # Log file name prefix.
    server.tomcat.accesslog.rename-on-rotate=false # Defer inclusion of the date stamp in the file name until rotate time.
    server.tomcat.accesslog.request-attributes-enabled=false # Set request attributes for IP address, Hostname, protocol and port used for the request.
    server.tomcat.accesslog.rotate=true # Enable access log rotation.
    server.tomcat.accesslog.suffix=.log # Log file name suffix.

    tomcat access默认配置

    127.0.0.1 - - [07/Oct/2016:22:31:56 +0800] “GET /dubbo/ HTTP/1.1” 404 963
    远程IP logical username remote user 时间和日期 http请求的第一行 状态码 除去http头的发送大小

     

    参考文件:https://www.cnblogs.com/chrischennx/p/6746214.html

                      https://maoyunfei.github.io/spring/76c7f26f/

                      https://qsli.github.io/2016/12/23/tomcat-access-log/

    展开全文
  • 有时候,查看log日志都要跑到服务器,或者把log文件下载下来看,还是比较麻烦的,今天咱们做个配置,让log日志可以在线查看。我使用的容器是Tomcat,所以,这是针对Tomcat的服务而言原理说起来非常简单,就是让生成...

    有时候,查看log日志都要跑到服务器,或者把log文件下载下来看,还是比较麻烦的,今天咱们做个配置,让log日志可以在线查看。我使用的容器是Tomcat,所以,这是针对Tomcat的服务而言

    原理说起来非常简单,就是让生成的日志到项目同级,在tomcat中作为一个静态资源项目可以通过网络在线查看,安全也不能忽视,不能让谁都能看到,这里我选择了让tomcat来负责账户权限校验,参考了tomcat自带示例manager的配置。

    首先,我们把日志文件保存的路径修改下,保存到项目的同级目录。在web.xml中添加一个配置,这里的webApp.root可以随意指定,参数名不可修改

    webAppRootKey

    webApp.root

    修改log4j.properties文件,修改一下日志文件的保存路径,这么简单一改,日志文件就保存到项目同级的log文件夹中了

    log4j.appender.D.File=${webApp.root}/../log/debug.log

    接着,我们再来添加下tomcat权限验证,在tomcat的webapps中创建一个log文件夹,然后创建一个WEB-INF文件夹,里面放上一个web.xml,内容如下

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee

    http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"

    version="3.0"

    metadata-complete="true">

    Log Application

    SetCharacterEncoding

    org.apache.catalina.filters.SetCharacterEncodingFilter

    encoding

    UTF-8

    SetCharacterEncoding

    /*

    Log Manager interface (for humans)

    /*

    log

    BASIC

    Tomcat Manager Application

    The role that is required to access the HTML Manager pages

    log

    上面指定了访问log项目时的账户角色为log,这个log角色的配置就要看tomcat/conf下的tomcat-users.xml了,在标签中把角色log加上,并加一个用户

    再给项目来个首页重定向,在log目录下添加一个index.jsp文件,内容只有一行,我这想默认就看到debug.log,所以就下面这么写

    访问下,看看效果

    f82a92e82619b175dca31acbc0539efe.png

    输入我们配置的账户log/123,登录,有没有看到日志,看到就说明大功告成了

    5d3f320c5b89046b508e838c2873a66d.png

    展开全文
  • 有时候,查看log日志都要跑到服务器,或者把log文件下载下来看,还是比较麻烦的,今天咱们做个配置,让log日志可以在线查看。我使用的容器是Tomcat,所以,这是针对Tomcat的服务而言 原理说起来非常简单,就是让...

    有时候,查看log日志都要跑到服务器,或者把log文件下载下来看,还是比较麻烦的,今天咱们做个配置,让log日志可以在线查看。我使用的容器是Tomcat,所以,这是针对Tomcat的服务而言

    原理说起来非常简单,就是让生成的日志到项目同级,在tomcat中作为一个静态资源项目可以通过网络在线查看,安全也不能忽视,不能让谁都能看到,这里我选择了让tomcat来负责账户权限校验,参考了tomcat自带示例manager的配置。

    • 首先,我们把日志文件保存的路径修改下,保存到项目的同级目录。在web.xml中添加一个配置,这里的webApp.root可以随意指定,参数名不可修改
      <!--日志文件路径映射到WEB-INF下-->
      <context-param>
        <param-name>webAppRootKey</param-name>
        <param-value>webApp.root</param-value>
      </context-param>

    • 修改log4j.properties文件,修改一下日志文件的保存路径,这么简单一改,日志文件就保存到项目同级的log文件夹中了
      log4j.appender.D.File=${webApp.root}/../log/debug.log

    • 接着,我们再来添加下tomcat权限验证,在tomcat的webapps中创建一个log文件夹,然后创建一个WEB-INF文件夹,里面放上一个web.xml,内容如下
      <?xml version="1.0" encoding="UTF-8"?>
      
      <web-app xmlns="http://java.sun.com/xml/ns/javaee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
                            http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
        version="3.0"
        metadata-complete="true">
      
        <display-name>Log Application</display-name>
        
        <filter>
          <filter-name>SetCharacterEncoding</filter-name>
          <filter-class>org.apache.catalina.filters.SetCharacterEncodingFilter</filter-class>
          <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
          </init-param>
        </filter>
      
        <filter-mapping>
          <filter-name>SetCharacterEncoding</filter-name>
          <url-pattern>/*</url-pattern>
        </filter-mapping>
      
        <!-- Define a Security Constraint on this Application -->
        <!-- NOTE:  None of these roles are present in the default users file -->
        <security-constraint>
          <web-resource-collection>
            <web-resource-name>Log Manager interface (for humans)</web-resource-name>
            <url-pattern>/*</url-pattern>
          </web-resource-collection>
          <auth-constraint>
             <role-name>log</role-name>
          </auth-constraint>
        </security-constraint>
      
        <!-- Define the Login Configuration for this Application -->
        <login-config>
          <auth-method>BASIC</auth-method>
          <realm-name>Tomcat Manager Application</realm-name>
        </login-config>
      
        <!-- Security roles referenced by this web application -->
        <security-role>
          <description>
            The role that is required to access the HTML Manager pages
          </description>
          <role-name>log</role-name>
        </security-role>
      
      </web-app>

    • 上面指定了访问log项目时的账户角色为log,这个log角色的配置就要看tomcat/conf下的tomcat-users.xml了,在<tomcat-users>标签中把角色log加上,并加一个用户
      <role rolename="log"/>
      <user username="log" password="123" roles="log"/>

    • 再给项目来个首页重定向,在log目录下添加一个index.jsp文件,内容只有一行,我这想默认就看到debug.log,所以就下面这么写
      <% response.sendRedirect(response.encodeRedirectURL(request.getContextPath() + "/debug.log")); %>

    • 访问下,看看效果


    输入我们配置的账户log/123,登录,有没有看到日志,看到就说明大功告成了


    展开全文
  • Tomcat log 中各种日志日志记录内容

    千次阅读 2018-12-08 16:06:15
    Tomcat log 中各种日志日志记录内容 内容1 catalina.log 记录tomcat启动时候的信息 localhost.log 记录运行日志 localhost_access_log 存放访问tomcat的请求的所有地址以及请求的路径、时间,请求协议以及返回码...
  • CentOS 7安装 tomcatyum安装tomcatyum install tomcattomcat webapp目录cd /var/lib/tomcattomcat配置文件目录cd /etc/tomcattomcat日志目录cd /var/log/tomcatftp上传war文件到 /var/lib/tom...文章nurmemet2017-07...
  • 1、先cd到tomcat目录下的logs目录:例:cd usr/local/tomcat5/logs 2、输入命令:tail -f catalina.out 其中catalina.out就是要查看的实时日志了。 3、这样运行时就可以实时查看运行日志
  • Tomcat配置log4j生成日志文件

    千次阅读 2016-05-27 16:39:31
    如端口占用问题,项目存在错误等导致Tomcat打不开的问题,这个时候就可以通过查看日志的方式来查找错误的原因,帮助我们减少开发过程中解决错误的时间,在这里提供一种Tomcat配置log4j替代java.util.logging来生成...
  • 今天在idea上启动Spring项目时,tomcat报错:Error during artifact deployment. See server log for details. 一直没找到具体日志在哪儿,后来终于找到了查看的方式,在此记录下: ...
  • 有时候,查看log日志都要跑到服务器,或者把log文件下载下来看,还是比较麻烦的,今天咱们做个配置,让log日志可以在线查看。我使用的容器是Tomcat,所以,这是针对Tomcat的服务而言 原理说起来非常简单,就是让...
  • tomcat配置log4j打印输出日志到指定文件 ...主题 Tomcat Log4J ... 在eclipse或myeclipse中使用tomcat启动项目可以在控制台输出相关日志,有时日志打印的多了查看的话很不方便,这时我们可以在我们使用
  • tomcat配置log4j输出日志到指定文件

    千次阅读 2016-07-12 19:26:28
    在eclipse或myeclipse中使用tomcat启动项目可以在控制台输出相关日志,有时日志打印的多了查看的话很不方便,这时我们可以在我们使用的tomcat中直接配置log4j来将我们需要看的日志打印输出到指定的文件中,这样便于...
  • tomcat查看日志命令

    2019-11-29 14:05:36
    tail -f 实时查看日志文件 tail -f 日志文件log tail - 100f 实时查看日志文件 后一百行 tail -f -n 100 catalina.out linux查看日志后100行 tail -f …/logs/catalina.out| grep " aaat" 监听实时日志" aaat" 的...
  • **问题描述:**因线上环境日志输出权限为640,当前用户没办法查看日志,想修改成644,但是log4j2版本低于2.9.0。 **解决办法:**将catalina.sh文件中UMASK 默认0027修改成0022 注意:存放日志当前目录所有人得有读...
  • Tomcat log4j 日志配置

    千次阅读 2012-04-12 16:06:12
    今天Tomcat发布的项目始终无法发布,总是报:严重: Error listenerStart 故赶紧配置了一下log4j查看详细调试日志,记录如下: 准备: 1.log4j.jar , 下载地址 : ...
  • cd home /tomcat/logs第二步:运行并查看日志:tail -f catalina.out第三步:想终止查看:ctrl +c退出第四步:比如通过关键字搜索:cat localhost.2018-07-05.log | grep 成功第五步:比如查看固定时间日志:cat ...
  • linux 查看tomcat 日志

    2018-11-22 11:40:00
    tomcat 重启: 2 cd /opt/appserver/apache-tomcat-9.0.2/bin 3 ./shutdown.sh 4 -ef|grep tomcat 5 kill -9 9812 ... 查看log日志 1 cd /www/server/apache-tomcat-8.5.32/logs 2 tail -f cat...
  • tomcat日志改用log4j

    2009-11-27 12:59:46
    昨天同事那边出了点故障, 一台tomcat服务器访问出错,tomcat是6.0版本的, 然后想查看tomcat日志却怎么也找不到最近的日志,logs下面 只有08年的几个日志文件。同事感觉很晕, 我也觉着奇怪, 照理说, tomcat默认...
  • 查看tomcat运行日志

    千次阅读 2017-08-22 15:39:33
    查看tomcat实时日志 tail -f catalina.out 通过关键字查看日志 cat jeewx-2017-08-22.log | grep 验证码 查看具体时间日志 cat jeewx-2017-08-22.log | grep '2015-09-20 18:50:15' 查看最近100行日志 tail -...
  • linux查看tomcat日志

    2017-03-03 16:23:16
    查看tomcat运行日志 tail -f catalina.out 通过关键字搜索查看日志 cat jeewx-2015-09-20.log | grep 验证码 查看固定时间日志 cat jeewx-2015-09-20.log ...
  • linux查看tomcat日志以及导出文件

    千次阅读 2017-08-17 10:23:22
    潘林搭建开发环境查看tomcat日志命令: journalctl -u tomcat 即时追踪查看服务器日志:journalctl -f -u tomcat 生成在当前文件夹 tomcat.log文件 journalctl -u tomcat -o short > ~/tomcat.log ...
  • 1.进入tomcat的logs: cd /opt/tomcat/logs 2. 输入命令:tail -f catalina.out 或者 tail -f project.log,结束用ctrl+C即可
  • 首先是进入到tomcat的logs下面 运行ls命令,看看都有什么文件 判断是否有catalina.out这个文件 如果这个文件tail -fcatalina.out就可以查看实时的日志了 但是如果没有上面的,比如:localhost.2019-05-23.log ...
  • Linux Tomcat启动服务并同时查看日志sh startup.sh & tail -fn 200 ../logs/catalina.outLinux Tomcat停止服务并同时查看日志sh shutdown.sh & tail -fn 200 ../logs/catalina.out
  • 正常打印日志 ...3、这样运行时就可以实时查看运行日志了 Ctrl+c 是退出tail命令。 搜索日志 grep '匹配的内容' -n catalina.log 或着 cat -n catalina.log | grep "匹配的内容" $grep -5 ‘partte...
  • tomcat改用log4j

    千次阅读 2011-04-21 22:10:00
    tomcat日志改用log4j 昨天同事那边出了点故障, 一台tomcat服务器访问出错,tomcat是6.0版本的, 然后想查看tomcat日志却怎么也找不到最近的日志,logs下面 只有08年的几个日志文件。同事感觉很晕, 我也觉着...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 643
精华内容 257
关键字:

tomcat查看log日志