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增强输出:
立即学习“Java免费学习笔记(深入)”;
- 添加文件输出:
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自带最可靠的日志基础。










