2014-10-29 61 views
6

在我的項目類中,我使用了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項目中的控制檯?

回答

8

幾個選項(我個人比較喜歡選擇2.2):

1)定製logging.properties文件:

的Java記錄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

定義在systemPropertybuild.gradle

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

添加defaultLogLevelRun.java

public static Level defaultLevel = Level.INFO; 

獲取logLevel屬性的值:

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

並設置記錄儀的定義級別:

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 

你可以控制顯示哪些消息。

+0

如果使用帶有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