Java里Logger类的基本用法是什么_Java日志基础API说明

发布时间 - 2026-01-05 00:00:00    点击率:
Java中Logger必须通过Logger.getLogger()获取实例,不可new;日志输出需检查Handler配置与级别设置;推荐用isLoggable()或占位符避免无效拼接;格式化由Handler的Formatter控制。

Java里用Logger前必须先获取实例

Java标准库的java.util.logging.Logger不是直接new出来的,必须通过Logger.getLogger(String name)获取。名字通常用类全限定名(如"com.example.MyService"),这样日志能按模块归类。重复调用同一名字会返回同一个实例,所以一般在类静态字段里初始化:

private static final Logger logger = Logger.getLogger(MyService.class.getName());

别写成new Logger()——它没有公开构造方法,编译就报错。

logger.info()等方法不打印任何内容?检查根处理器

默认情况下,Logger实例本身不输出日志,它把日志交给handler处理。JUL(Java Util Logging)默认只给根Logger配了ConsoleHandler,但子Logger默认useParentHandlers == true,所以多数情况能打到控制台。但如果发现logger.info("test")没输出,常见原因有:

  • Logger被显式设置了setUseParentHandlers(false),又没加自己的Handler
  • LoggerLevel设成了WARNING或更高,而info()INFO
  • 应用服务器(如Tomcat)重置了JUL配置,屏蔽了控制台输出

快速验证:加一行logger.getParent().getLevel()看看根级别是不是INFO或更低。

日志级别和isLoggable()不是摆设

Logger支持SEVEREWARNINGINFOCONFIGFINEFINERFINEST七级,默认启用到INFO。但注意:logger.info("user=" + user)这种写法,不管当前级别是否允许输出,都会先执行字符串拼接——可能浪费CPU或触发副作用(比如user.toString()抛异常)。

正确做法是用isLoggable(Level.INFO)提前判断,或改用带占位符的log(Level.INFO, "user={0}", user)(JUL原生支持{0}语法,仅当真正记录时才解析参数):

if (logger.isLoggable(Level.FINE)) {
    logger.fine("Processing item: " + expensiveToString(item));
}
// 或更简洁:
logger.log(Level.FINE, "Processing item: {0}", item);

别依赖Logger的默认格式,自定义Formatter才可靠

JUL默认用SimpleFormatter,输出类似Jun 12, 2025 3:45:22 PM com.example.MyService doWork INFO: done。时间格式、类名、线程名都固定,很难适配监控系统或ELK。要改输出格式,得替换HandlerFormatter

ConsoleHandler handler = new ConsoleHandler();
handler.setFormatter(new MyCustomFormatter()); // 继承 Formatter 重写 format()
logger.addHandler(handler);

但注意:每个Handler独立持有Formatter,如果同时用了FileHandlerConsoleHandler,得分别设置。另外,Logger本身不保存格式信息,所有格式化逻辑都在Handler侧。

实际项目中,JUL很少单独用到底层定制;更多是作为SLF4J桥接目标,或者被Log4j2/Logback替代。真要用JUL,重点盯住Handler生命周期和Level继承链——这两处出问题,日志就静默消失。


# java  # 处理器  # tomcat  # 标准库 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 动图在线制作网站有哪些,滑动动图图集怎么做?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  iOS中将个别页面强制横屏其他页面竖屏  Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  简历没回改:利用AI润色让你的文字更专业  如何用PHP工具快速搭建高效网站?  详解vue.js组件化开发实践  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  教你用AI将一段旋律扩展成一首完整的曲子  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  如何确认建站备案号应放置的具体位置?  再谈Python中的字符串与字符编码(推荐)  Laravel怎么实现验证码(Captcha)功能  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  如何在Windows服务器上快速搭建网站?  网站页面设计需要考虑到这些问题  JS碰撞运动实现方法详解  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  如何正确下载安装西数主机建站助手?  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  如何在腾讯云服务器上快速搭建个人网站?  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  使用Dockerfile构建java web环境  Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧  原生JS获取元素集合的子元素宽度实例  Laravel如何实现事件和监听器?(Event & Listener实战)  北京企业网站设计制作公司,北京铁路集团官方网站?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  QQ浏览器网页版登录入口 个人中心在线进入  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  微信小程序 scroll-view组件实现列表页实例代码  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  微信小程序 HTTPS报错整理常见问题及解决方案  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  网站建设要注意的标准 促进网站用户好感度!  移动端脚本框架Hammer.js  长沙做网站要多少钱,长沙国安网络怎么样?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  如何在云主机上快速搭建多站点网站?  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  百度输入法ai组件怎么删除 百度输入法ai组件移除工具  ,怎么在广州志愿者网站注册?