gpt4 book ai didi

java - 如何通过maven项目的LOG_LEVEL过滤jetty日志?

转载 作者:行者123 更新时间:2023-12-01 09:36:14 25 4
gpt4 key购买 nike

我在登录 jetty 时遇到问题。我将日志写入文件中。在生成的日志文件中,应用程序的日志记录级别是信息,但我将其设置为警告。我认为jetty从应用程序写入日志而不进行过滤,是这样吗?

  1. 我使用 maven,并使用命令打包了我的应用程序

    sudo mvn package
  2. 为 jetty 设置日志记录:

    {jetty.base}/modules$ sudo curl -O https://raw.githubusercontent.com/jetty-project/logging-modules/master/log4j-1.2/logging.mod

    {jetty.base}$ sudo java -jar /opt/jetty/start.jar --add-to-start=logging
  3. 文件 {jetty.base}/resources/jetty-logging.properties

    org.eclipse.jetty.util.log.class=org.eclipse.jetty.util.log.Slf4jLog
    org.apache.log4j.LogManager.getLogger("org.eclipse.jetty").setLevel(Level.WARN);
    org.eclipse.jetty.LEVEL=WARN
  4. 文件 {jetty.base}/resources/log4j.properties

    log4j.rootLogger=WARN, file
    log4j.appender.file=org.apache.log4j.RollingFileAppender
    log4j.appender.file.layout=org.apache.log4j.PatternLayout
    log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
  5. 文件 {jetty.base}/etc/jetty-logging.xml

    <New id="ServerLog" class="java.io.PrintStream">
    <Arg>
    <New class="org.eclipse.jetty.util.RolloverFileOutputStream">
    <Arg><Property name="jetty.logs" default="/mnt/logs"/>/yyyy_mm_dd.stderrout.log</Arg>
    <Arg type="boolean">false</Arg>
    <Arg type="int">90</Arg>
    <Arg><Call class="java.util.TimeZone" name="getTimeZone"><Arg>GMT</Arg></Call></Arg>
    <Get id="ServerLogName" name="datedFilename"/>
    </New>
    </Arg>
    </New>

    <Get name="rootLogger">
    <Call name="info"><Arg>Redirecting stderr/stdout to file <Ref refid="ServerLogName"/></Arg></Call>
    </Get>
    <Call class="java.lang.System" name="setErr"><Arg><Ref refid="ServerLog"/></Arg></Call>
    <Call class="java.lang.System" name="setOut"><Arg><Ref refid="ServerLog"/></Arg></Call>

  6. 在日志文件中,我看到级别为 Info 和 debug 的日志记录

    07:13:10.072 [main] INFO 
    07:14:04.216 [java-sdk-http-connection-reaper] DEBUG o.a.h.i.c.PoolingClientConnectionManager ...

最佳答案

忽略etc/jetty-logging.xml,您的设置没有使用它(您下载了一个未引用它的自定义modules/logging.mod)

You can see what your configuration is using by running start.jar --list-config

该 XML 的存在只是为了支持内置的 StdErrLog 实现,该实现仅写入 System.err(又名 STDERR)。 etc/jetty-logging.xml 仅获取 STDERR 和 STDOUT 并将其写入磁盘。

由于您使用的是 log4j,因此不需要整个重定向步骤(如果使用的话,会与正常的 log4j 控制台附加程序行为发生冲突)。

您的${jetty.base}/resources/jetty-logging.properties 只能是:

org.eclipse.jetty.util.log.class=org.eclipse.jetty.util.log.Slf4jLog

它不应包含其他行。

文件 ${jetty.base}/resources/log4j.properties 是您配置初始命名记录器级别以及要使用的所有初始附加程序的位置。

您当前的初始级别设置为 WARN。

当您的服务器启动时,您拥有的任何代码都可以(在运行时)决定更改特定命名记录器的级别,甚至在运行时添加/删除附加程序(这比您想象的更常见)

由于您没有为附加程序声明Threshold,因此它将采用看到的所有级别并附加它们。

如果您不想在附加程序中看到该 DEBUG,只需将以下行添加到您的 ${jetty.base}/resources/log4j.properties

log4j.appender.file.Threshold=WARN

但是您可能仍然想知道在属性文件之外设置指定记录器级别的内容是什么。 (检查您的代码)

关于java - 如何通过maven项目的LOG_LEVEL过滤jetty日志?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38890083/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com