在我的項目類中,我使用了java.util.logging.Logger
,並在我的代碼中添加了各種日誌輸出,使用各種日誌級別即。Gradle Logging Output Levels
的src /主/爪哇/ 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目錄/主/資源/記錄。特性
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運行當我得到: 成功啓動進程 '命令' /Library/Java/JavaVirtualMachines/jdk1.8.0_20 .jdk/Contents/Home/bin/java' Hello World :run(Thread [main,5,main])完成。花了0.202秒。
BUILD SUCCESSFUL
即,沒有日誌信息。但是從運行的任務和內註釋掉system.properties重新運行gradle這個-i運行我得到:
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項目中的控制檯?
如果使用帶有logback的SLF4J,請注意接口'org.slf4j.Logger'沒有'setLevel'方法。但是'ch.qos.logback.classic.Logger'實現了這個接口並且有這個方法。爲了創建'Logger',你需要導入後面的類,然後如下所示:'Logger LOGGER =(Logger)LoggerFactory.getLogger(MyClass.class)' – 2016-11-07 08:12:18