【发布时间】: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 项目中获取配置、精细和更精细级别的日志以登录到控制台?
【问题讨论】: