在Java里如何使用Logger记录日志_Java日志基础API解析

Java中使用JUL日志需通过Logger.getLogger()获取实例,按层级命名,常用INFO/WARNING/SEVERE级别,可添加Handler和Formatter自定义输出,支持properties配置全局行为。

Java中使用Logger记录日志,核心是通过java.util.logging.Logger(JUL)获取实例并调用info()warning()severe()等方法。它无需额外依赖,但默认配置简单,适合轻量场景。

获取Logger实例

Logger不能直接new,必须通过Logger.getLogger(String name)获取。name通常用类全限定名,便于区分来源:

  • 推荐写法:private static final Logger logger = Logger.getLogger(MyClass.class.getName());
  • name具有层级关系,如"com.example""com.example.service"共享父Logger配置
  • 避免用空字符串或随机字符串,否则难以统一管理

常用日志级别与方法

JUL定义了7个标准级别,从低到高为:FINEST、FINER、FINE、CONFIG、INFO、WARNING、SEVERE。常用的是:

  • logger.info("服务启动完成") —— 一般运行信息
  • logger.warning("配置文件缺失,使用默认值") —— 可恢复的异常情况
  • logger.severe("数据库连接失败:" + e.getMessage()) —— 致命错误,影响主流程
  • 不建议在生产环境用finest()等调试级方法,除非显式启用对应级别

自定义Handler和Formatter

默认只输出到控制台,且格式简陋。可通过添加Handler并设置Formatter增强输出:

  • 添加文件输出:logger.addHandler(new FileHandler("app.log"))
  • 美化格式:logger.getHandlers()[0].setFormatter(new SimpleFormatter())
  • 若多个Handler共存,需分别设置Formatter;每个Handler可独立控制输出目标和格式
  • 注意FileHandler默认会追加日志,如需覆盖旧文件,构造时传false参数

配置全局日志行为

可通过Logging.properties文件或代码方式修改根Logger行为:

  • 加载外部配置:LogManager.getLogManager().readConfiguration(new FileInputStream("logging.properties"))
  • 禁用父处理器(避免重复输出):logger.setUseParentHandlers(false)
  • 调整根Logger级别:Logger.getLogger("").setLevel(Level.INFO)
  • 修改后需确保子Logger未显式关闭继承,否则配置可能不生效

不复杂但容易忽略。用好JUL的关键是理解层级结构、合理设级别、及时配Handler——尤其在没有引入Log4j或SLF4J时,它是JDK自带最可靠的日志基础。