用Java日志包进行调试

作者: Builder.com
Tuesday, April 6 2004 11:23 AM

本文译自Builder.com,未经许可请勿转载

在JAVA1.4引入了一个日志包java.util.logging。如果你已经使用过以前的普通日志结构框架——log4j的话,那么有关Java的内部记录部分你将非常熟悉了。

你可以在不安装的前提下使用日志包。其中最简单的方法就是建立一个Java.util.logging.Logger的实例。一旦建立好这个实例,你就可以开始记录了。下面是一个记录类的完整例子:

package tips;

import java.util.logging.Logger;

public class LogTip {
    // create an instance of the Logger class
    private static Logger log = Logger.getLogger("tips.LogTip");

    public static void main(String args[]) {
        log.finest("the finest message");
        log.finer("finer message");
        log.fine("a fine message");
        log.config("some configuration message");
        log.info("a little bit of information");
        log.warning("a warning message");
        log.severe("a severe message");
    }
}

你在编译运行这个类的时候,你的控制台中就会有以下的输出显示:

Apr 1, 2003 11:09:05 PM tips.LogTip main
INFO: a little bit of information
Apr 1, 2003 11:09:05 PM tips.LogTip main
WARNING: a warning message
Apr 1, 2003 11:09:05 PM tips.LogTip main
SEVERE: a severe message

并不是所有的记录项都会显示在控制台中,这是因为Java的日志包应用了日志级别别。日志级别允许你控制记录输出。在开发过程中,你希望得到大量的调试信息,从而你可以了解你的应用程序将会出现什么问题。

但作为产品,你就不希望他输出调试结果并且不出错。你也可以通过使用日志包中的日志级别别来控制。

在Java.util.logging.Level这个类中定义了7种日志级别别,他们分别是:SEVERE,WARNING, INFO,CONFIG,FINE, FINER和FINEST。其中SEVERE即用于处理错误以及灾难事件。而FINE,FINER和FINEST级是用于处理一些不那么重要的信息,以及用于程序调试。

另外,你可以将日志级别别设定为ALL或者OFF来设定它的极值。当你将其设定为ALL的时候,所有的记录项都为开放的,相反,当你设定为OFF的时候,所有的记录项都为禁止的。

由于日志级别别是分层次的,当你将其定义为某一级别后,就只有此级别或是更高级别的能被记录。在七种级别中SEVERE是最高级别,FINEST是最低级别。默认级别是INFO;这就是我们在上面代码段中只看到三个记录信息的原因。如果想看到所有的记录信息的话,我们就要改变一下设置。

有很多方法来改变默认设置,比如用工具文件,对运行时间编程或是提出你自己的结构类。如果你通过工具选项来设置记录的话,你有两种选择,一是你可以用默认的道具文件(这种方法不推荐)——%YOUR_JRE_PATH%/lib/logging.properties;还有就是你可以通过设定系统文件java.util.logging.config.file,将其指定到你需要使用的文件名自己设置道具文件,方法如下:

java -Djava.util.logging.config.file=log.properties tips.LogTip。

这样的话不能从log.properties文件中度出任何地记录工具,在这个例子中,这是默认的logging.properties文件的改版,具体如下:

handlers= java.util.logging.ConsoleHandler
   .level=FINEST
   java.util.logging.ConsoleHandler.level = FINEST
    java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter

当运行这个类的时候,就会有以下的输出显示:

Apr 1, 2003 11:12:00 PM tips.LogTip main
FINEST: the finest message
Apr 1, 2003 11:12:00 PM tips.LogTip main
FINER: finer message
Apr 1, 2003 11:12:00 PM tips.LogTip main
FINE: a fine message
Apr 1, 2003 11:12:00 PM tips.LogTip main
CONFIG: some configuration message
Apr 1, 2003 11:12:00 PM tips.LogTip main
INFO: a little bit of information
Apr 1, 2003 11:12:00 PM tips.LogTip main
WARNING: a warning message
Apr 1, 2003 11:12:00 PM tips.LogTip main
SEVERE: a severe message

在实际应用中,你需要对记录尽可能多的控制。你学要将某些记录定义为FINEST,某些类记录为SEVERE或是其他级别。你也可能需要记录一些关于控制台的信息,或是一些关于文件的信息,甚至有时是关于数据库的信息。



责任编辑:李宁

欢迎评论投稿


本文为ZDNet China版权所有,未经许可严禁转载。
### Java 中的日志调试方法及示例代码 在 Java 开发中,日志调试是识别和分析程序运行状态的重要手段。通过日志记录,开发者可以在不打断程序运行的前提下,查看关键变量、流程分支、异常信息等,从而提升问题排查效率。 #### 使用 SLF4J 和 Logback 输出日志 SLF4J(Simple Logging Facade for Java)是一个日志门面框架,它为各种日志实现(如 Logback、Log4j)提供统一的接口,便于日志系统的切换和集成。Logback 是 SLF4J 的原生实现,性能优越,配置灵活,广泛用于 Java 项目中。 **示例代码**: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class Slf4jLogbackExample { private static final Logger logger = LoggerFactory.getLogger(Slf4jLogbackExample.class); public static void main(String[] args) { logger.debug("This is a debug message"); logger.info("This is an info message"); logger.warn("This is a warning message"); logger.error("This is an error message"); try { int result = 10 / 0; } catch (ArithmeticException e) { logger.error("Arithmetic exception occurred", e); } } } ``` 通过设置 `logback.xml` 配置文件,可以控制日志的输出格式、路径和级别,从而适应不同环境下的调试需求。 #### 使用 Log4j2 记录日志 Log4j2 是 Apache 提供的日志实现,具有高性能、支持异步日志、自动重载配置等特性。它适用于需要高并发日志处理的场景。 **示例配置(log4j2.xml)**: ```xml <?xml version="1.0" encoding="UTF-8"?> <Configuration status="WARN"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n"/> </Console> </Appenders> <Loggers> <Root level="debug"> <AppenderRef ref="Console"/> </Root> </Loggers> </Configuration> ``` **Java 示例代码**: ```java import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; public class Log4j2Example { private static final Logger logger = LogManager.getLogger(Log4j2Example.class); public static void main(String[] args) { logger.debug("Debug message"); logger.info("Info message"); logger.error("Error message"); } } ``` 上述配置文件定义了日志输出格式和目标为控制台,开发者可根据需要扩展为文件输出、远程日志服务器等。 #### 动态调整日志级别 Java 日志系统支持运行时动态修改日志级别,这在生产环境中非常有用。例如,可以通过管理接口或配置中心临时提升日志级别,以便收集更详细的调试信息。 **示例方法**: ```java import org.slf4j.LoggerFactory; import ch.qos.logback.classic.Level; import ch.qos.logback.classic.Logger; public class LogLevelAdjustExample { public static void main(String[] args) { Logger targetLogger = (Logger) LoggerFactory.getLogger("com.example.MyService"); targetLogger.setLevel(Level.DEBUG); // 动态设置为 DEBUG 级别 targetLogger.debug("This debug message will be logged now"); } } ``` 此方法适用于 Logback,对于 Log4j2 可通过 `ConfigMap` 或 `JMX` 实现类似功能。 #### 集成 ELK Stack 进行集中日志管理 在分布式系统中,Java 应用通常部署在多个节点上,为了统一收集和分析日志,可以使用 ELK Stack(Elasticsearch、Logstash、Kibana)进行日志聚合。 **Logstash 配置示例**: ```conf input { file { path => "/var/log/myapp/*.log" start_position => "beginning" } } filter { grok { match => { "message" => "%{TIMESTAMP_ISO8601:timestamp} %{LOGLEVEL:level} %{JAVACLASS:class} - %{GREEDYDATA:message}" } } } output { elasticsearch { hosts => ["http://localhost:9200"] index => "logs-%{+YYYY.MM.dd}" } stdout { codec => rubydebug } } ``` 该配置文件从指定路径读取日志文件,使用 `grok` 解析日志格式,并将结果发送到 Elasticsearch,便于后续通过 Kibana 进行可视化分析。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值