【问题标题】:Gradle Logging Output LevelsGradle 日志记录输出级别
【发布时间】:2014-12-25 11:18:50
【问题描述】:

在我的项目类中,我使用了java.util.logging.Logger,并在我的代码中添加了各种日志输出,使用各种日志级别,即。

src/main/java/Run.java

import java.util.logging.Level;
import java.util.logging.Logger;

public class Run{


    public static void main( String args[] ){
      System.out.println("Hello World");

      logger.log(Level.CONFIG, "Just some config info");
      Logger logger = Logger.getLogger(Run.class.getName());
      logger.log(Level.INFO, "Just logging some info");
      logger.log(Level.FINE, "Fine logging");
      logger.log(Level.FINER, "Finer logging");
      logger.log(Level.WARNING, "This is a warning log!");

    }
}

目前,当我运行gradle -i test 时,所有定义了Level.INFO 的日志消息都会显示,但没有输出任何配置、警告或罚款消息。

我已尝试更新我的 build.gradle 文件,以便:

apply plugin: 'java'
apply plugin:'application'
mainClassName = "Run"

repositories {
    mavenCentral()
}

dependencies {
    testCompile "junit:junit:4.11"
}

run{
    systemProperties = ['java.util.logging.config.file' : 'logging.properties']
}

我已经包括:

systemProperties = ['java.util.logging.config.file' : 'logging.properties']

然后创建/src/main/resource/logging.propertiess

handlers= java.util.logging.ConsoleHandler
.level= CONFIG
java.util.logging.ConsoleHandler.level = FINER
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter

跑步:

gradle run

我明白了:

:compileJava UP-TO-DATE
:processResources UP-TO-DATE
:classes UP-TO-DATE
:run
Hello World

BUILD SUCCESSFUL

当运行 gradle -i run 我得到: 成功启动进程'command'/Library/Java/JavaVirtualMachines/jdk1.8.0_20.jdk/Contents/Home/bin/java'' 你好世界 :run (Thread[main,5,main]) 完成。耗时 0.202 秒。

BUILD SUCCESSFUL

即。没有日志信息。但是,从运行任务中注释掉 system.properties 并重新运行 gradle -i run 我得到:

Successfully started process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_20.jdk/Contents/Home/bin/java''
Hello World
Nov 05, 2014 12:07:42 PM Run main
INFO: Just logging some info
Nov 05, 2014 12:07:42 PM Run main
WARNING: This is a warning log!
:run (Thread[main,5,main]) completed. Took 0.229 secs.

BUILD SUCCESSFUL

信息和警告级别日志,但不是精细或更精细的日志。

tldr;

如何在通用 gradle java 项目中获取配置、精细和更精细级别的日志以登录到控制台?

【问题讨论】:

    标签: java logging gradle


    【解决方案1】:

    几个选项(我个人更喜欢选项 2.2):

    1) 自定义 logging.properties 文件:

    Java Logging API 在<JRE_HOME>/lib/logging.properties 有一个默认的日志记录配置文件。您可以使用自己的配置文件设置 JVM 属性 java.util.logging.config.file

    handlers = java.util.logging.ConsoleHandler
    
    Run.handlers = java.util.logging.ConsoleHandler
    Run.level = FINER
    Run.useParentHandlers = false
    
    java.util.logging.ConsoleHandler.level = ALL
    java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter
    

    您必须设置useParentHandlers = false 以避免从父处理程序获得重复打印。

    1.1) 用绝对路径设置上述属性

    甚至没有尝试 ;-)

    1.2) 在Run.java中加载自定义文件如下

    Run.java中加载如下:

        InputStream inputStream = Run.class.getResourceAsStream("mylogging.properties");
        try {
            LogManager.getLogManager().readConfiguration(inputStream);
        } catch(Exception e) {
            e.printStackTrace();
        }
    

    2) 自定义系统属性(即:logLevel

    在你的build.gradle中定义一个systemProperty

    run {
        systemProperty 'logLevel', System.getProperty('logLevel')
    }
    

    Run.java 中添加defaultLogLevel

    public static Level defaultLevel = Level.INFO;
    

    获取logLevel属性的值:

    String logLevel = System.getProperty("logLevel");
    

    并在logger中设置定义的级别:

    Logger logger = Logger.getLogger(Run.class.getName());
    logger.setLevel(logLevel.isEmpty() ? defaultLevel : Level.parse(logLevel));
    

    2.1) 创建一个新的ConsoleHandler 并关闭父处理程序的打印

        System.out.println(Run.class.getName());
        Logger logger = Logger.getLogger(Run.class.getName());
        logger.setLevel(logLevel.isEmpty() ? defaultLevel : Level.parse(logLevel));
    
        Handler consoleHandler = new ConsoleHandler();
        consoleHandler.setLevel(logLevel.isEmpty() ? defaultLevel : Level.parse(logLevel));
        logger.addHandler(consoleHandler);
    
        logger.setUseParentHandlers(false);
    

    2.2) 找到父级ConsoleHandler 并设置定义的级别

        Logger topLogger = Logger.getLogger("");
    
        Handler consoleHandler = null;
        for (Handler handler : topLogger.getHandlers()) {
            if (handler instanceof ConsoleHandler) {
                //found the console handler
                consoleHandler = handler;
                break;
            }
        }
    
        if (consoleHandler == null) {
            // not found, create a new one
            consoleHandler = new ConsoleHandler();
            topLogger.addHandler(consoleHandler);
        }
        //set the console handler level
        consoleHandler.setLevel(logLevel.isEmpty() ? defaultLevel : Level.parse(logLevel));
    

    这样,gradle run 会产生高于默认级别 (INFO) 的消息。与

    gradle run -DlogLevel=FINE
    

    您可以控制显示哪些消息。

    【讨论】:

    • 如果使用带有 logback 的 SLF4J,请注意接口 org.slf4j.Logger 没有方法 setLevel。但是ch.qos.logback.classic.Logger实现了这个接口,有这个方法。因此,要创建 Logger,您必须导入后一个类,然后按如下方式进行转换:Logger LOGGER = (Logger)LoggerFactory.getLogger(MyClass.class)
    猜你喜欢
    • 1970-01-01
    • 2011-05-06
    • 1970-01-01
    • 1970-01-01
    • 2016-11-27
    • 2014-12-03
    • 1970-01-01
    • 1970-01-01
    • 2023-03-23
    相关资源
    最近更新 更多