当前位置: 首页 > news >正文

聊聊logback的isDebugEnabled

本文主要研究一下logback的isDebugEnabled

isDebugEnabled

public final class Loggerimplements org.slf4j.Logger, LocationAwareLogger, LoggingEventAware, AppenderAttachable<ILoggingEvent>, Serializable {//......public boolean isDebugEnabled() {return isDebugEnabled(null);}public boolean isDebugEnabled(Marker marker) {final FilterReply decision = callTurboFilters(marker, Level.DEBUG);if (decision == FilterReply.NEUTRAL) {return effectiveLevelInt <= Level.DEBUG_INT;} else if (decision == FilterReply.DENY) {return false;} else if (decision == FilterReply.ACCEPT) {return true;} else {throw new IllegalStateException("Unknown FilterReply value: " + decision);}}        }        

isDebugEnabled先通过callTurboFilters获取debug级别的FilterReply,若为DENY返回false,若为ACCEPT返回true,若为NEUTRAL则判断effectiveLevelInt是否小于等于DEBUG_INT

callTurboFilters

    /*** Method that calls the attached TurboFilter objects based on the logger and* the level.* * It is used by isYYYEnabled() methods.* * It returns the typical FilterReply values: ACCEPT, NEUTRAL or DENY.* * @param level* @return the reply given by the TurboFilters*/private FilterReply callTurboFilters(Marker marker, Level level) {return loggerContext.getTurboFilterChainDecision_0_3OrMore(marker, this, level, null, null, null);}

callTurboFilters从loggerContext获取getTurboFilterChainDecision_0_3OrMore

getTurboFilterChainDecision_0_3OrMore

ch/qos/logback/classic/LoggerContext.java

    final FilterReply getTurboFilterChainDecision_0_3OrMore(final Marker marker, final Logger logger, final Level level,final String format, final Object[] params, final Throwable t) {if (turboFilterList.size() == 0) {return FilterReply.NEUTRAL;}return turboFilterList.getTurboFilterChainDecision(marker, logger, level, format, params, t);}

该方法先判断turboFilterList是否为空,为空则返回NEUTRAL,否则执行turboFilterList.getTurboFilterChainDecision

getTurboFilterChainDecision

ch/qos/logback/classic/spi/TurboFilterList.java

    public FilterReply getTurboFilterChainDecision(final Marker marker, final Logger logger, final Level level,final String format, final Object[] params, final Throwable t) {final int size = size();// if (size == 0) {// return FilterReply.NEUTRAL;// }if (size == 1) {try {TurboFilter tf = get(0);return tf.decide(marker, logger, level, format, params, t);} catch (IndexOutOfBoundsException iobe) {return FilterReply.NEUTRAL;}}Object[] tfa = toArray();final int len = tfa.length;for (int i = 0; i < len; i++) {// for (TurboFilter tf : this) {final TurboFilter tf = (TurboFilter) tfa[i];final FilterReply r = tf.decide(marker, logger, level, format, params, t);if (r == FilterReply.DENY || r == FilterReply.ACCEPT) {return r;}}return FilterReply.NEUTRAL;}

getTurboFilterChainDecision在只有1个TurboFilter的时候执行decide方法,否则遍历TurboFilter,挨个执行decide,一但有DENY或者ACCEPT直接返回,否则最后返回NEUTRAL

小结

logback的isDebugEnabled先通过callTurboFilters获取debug级别的FilterReply,若为DENY返回false,若为ACCEPT返回true,若为NEUTRAL则判断effectiveLevelInt是否小于等于DEBUG_INT。callTurboFilters是一系列isYYYEnabled()共用的,它在turboFilterList是否为空,为空则返回NEUTRAL,在只有1个TurboFilter的时候执行decide方法,否则遍历TurboFilter,挨个执行decide,一但有DENY或者ACCEPT直接返回,否则最后返回NEUTRAL。

http://www.lryc.cn/news/228308.html

相关文章:

  • ChatGPT+Roblox,元宇宙的AI叙事逻辑#Leveling Up
  • Spark算子
  • Containerd接入Harbor仓库
  • Angular 组件介绍及使用(一)
  • 2023.11.13 hive数据仓库之分区表与分桶表操作,与复杂类型的运用
  • Spring Cloud学习(七)【Docker 容器】
  • 好题分享(2023.11.5——2023.11.11)
  • 第二章 03Java基础-IDEA相关叙述
  • 第三阶段第二章——Python高阶技巧
  • 【Git】Git分支与应用分支Git标签与应用标签
  • 本地PHP搭建简单Imagewheel私人云图床,在外远程访问——“cpolar内网穿透”
  • HCIP---OSPF思维导图
  • Python实现猎人猎物优化算法(HPO)优化XGBoost回归模型(XGBRegressor算法)项目实战
  • pandas读写json的知识点
  • 图论——Dijkstra算法matlab代码
  • [MySQL] MySQL表的基础操作
  • SQL 部分解释。
  • 利用LangChain实现RAG
  • 零基础学习Matlab,适合入门级新手,了解Matlab
  • CCF ChinaSoft 2023 论坛巡礼 | 自动驾驶仿真测试论坛
  • vue封装useWatch hook支持停止监听和重启监听功能
  • 智能配方颗粒管理系统解决方案,专业实现中医药产业数字化-亿发
  • PXI总线测试模块-6951E 信号分析仪
  • 精确杂草控制植物检测模型的改进推广
  • C++:对象成员方法的使用
  • 深入了解SpringMvc接收数据
  • 华东“启明”青少年音乐艺术实践中心揭幕暨中国“启明”巴洛克合奏团首演音乐会
  • 17. 机器学习——SVM
  • 算法导论笔记5:贪心算法
  • Vue的高级表格组件库【vxe-table】