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

聊聊logback的LevelFilter

本文主要研究一下logback的LevelFilter

AbstractMatcherFilter

ch/qos/logback/core/filter/AbstractMatcherFilter.java

public abstract class AbstractMatcherFilter<E> extends Filter<E> {protected FilterReply onMatch = FilterReply.NEUTRAL;protected FilterReply onMismatch = FilterReply.NEUTRAL;final public void setOnMatch(FilterReply reply) {this.onMatch = reply;}final public void setOnMismatch(FilterReply reply) {this.onMismatch = reply;}final public FilterReply getOnMatch() {return onMatch;}final public FilterReply getOnMismatch() {return onMismatch;}
}

AbstractMatcherFilter继承了Filter,它定义了onMatch及onMismatch属性

LevelFilter

ch/qos/logback/classic/filter/LevelFilter.java

public class LevelFilter extends AbstractMatcherFilter<ILoggingEvent> {Level level;@Overridepublic FilterReply decide(ILoggingEvent event) {if (!isStarted()) {return FilterReply.NEUTRAL;}if (event.getLevel().equals(level)) {return onMatch;} else {return onMismatch;}}public void setLevel(Level level) {this.level = level;}public void start() {if (this.level != null) {super.start();}}
}

LevelFilter继承了AbstractMatcherFilter,其decide判断event的level等级是否与配置的level一致,一致则返回onMatch,否则返回onMismatch

示例

    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"><filter class="ch.qos.logback.classic.filter.LevelFilter"><level>ERROR</level><onMatch>ACCEPT</onMatch><onMismatch>DENY</onMismatch></filter><encoder><pattern>${CONSOLE_LOG_PATTERN}</pattern></encoder></appender>

这里CONSOLE的appender定义了LevelFilter,当level为ERROR级别时ACCEPT,否则DENY

小结

logback提供了LevelFilter,可以配置指定的level、onMatch、onMismatch属性,用于设置指定appender的打印级别。

相关文章:

聊聊logback的LevelFilter

序 本文主要研究一下logback的LevelFilter AbstractMatcherFilter ch/qos/logback/core/filter/AbstractMatcherFilter.java public abstract class AbstractMatcherFilter<E> extends Filter<E> {protected FilterReply onMatch FilterReply.NEUTRAL;protect…...

mysql 行转列 GROUP_CONCAT 试验

1.概要 很多时候需要用到行专列的方式做数据分析。比如对通讯数据的采集 数据采集结果如下&#xff1a; 变量值采集周期131251132272 我想要看的结果 变量1变量2采集周期351372 就是我想看到相关数据的周期变化情况。 2.试验 2.1创建数据如下&#xff08;表名 tb5&…...

HarmonyOS元服务开发实战—端云一体化开发

还记得我第一次接触arkui还是在22年的9月份&#xff0c;当时arkui还在一个比较初试的阶段。时隔一年再见方舟框架&#xff0c;它已经发生了令人瞩目的变化&#xff0c;不得不说华为方舟框架在更新迭代的速度已经遥遥领先。新的功能和性能优化让这个框架更加强大和灵活&#xff…...

【搭环境】装Python3.8 open3d

先装Python3.8 方法一试了找不到Python3.8的库&#xff0c;所以用方法二装上了。 Python3加入环境变量 更改Python默认指向 open3d需要Python3.6以上&#xff0c;最好用Ubuntu18版本&#xff0c;我用的16版本。。...

【C语言】深入解开指针(四)

&#x1f308;write in front :&#x1f50d;个人主页 &#xff1a; 啊森要自信的主页 ✏️真正相信奇迹的家伙&#xff0c;本身和奇迹一样了不起啊&#xff01; 欢迎大家关注&#x1f50d;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;>希望看完我的文章对你有小小的帮助&am…...

AMEYA360:瑞萨面向高端工业传感器系统推出高精度模拟前端的32位RX MCU

全球半导体解决方案供应商瑞萨电子&#xff08;TSE&#xff1a;6723&#xff09;宣布面向高端工业传感器系统推出一款全新RX产品——RX23E-B&#xff0c;扩展32位微控制器&#xff08;MCU&#xff09;产品线。新产品作为广受欢迎的RX产品家族的一员&#xff0c;具有高精度模拟前…...

切面Aspect + 策略模式实现待办提醒功能

1.背景 产品需要实现一个待办提醒功能&#xff0c;就是核心业务发生变更即提醒业务员去处理相关业务。譬如&#xff1a;订单上传了支付凭证&#xff0c;那么就会提醒相关业务员去待办列表操办。 2.表设计 其实表设计主要是两张表sys_todo、sys_todo_detail 一张是待办核心表…...

SAP 调取http的x-www-form-urlencoded形式的接口

一、了解下x-www-form-urlencoded形式对于SAP来说有啥区别 简单来说&#xff0c; 1.raw格式就是标准的json格式&#xff1a;{“Name”:“John Smith”&#xff0c;“Age”: 23} 2.x-www格式是要转化一下的&#xff1a;NameJohnSmith&Age23 字段与字段相互连接要用 & 符…...

thingsboard3.6的mailConfigTemplateController错误

1、bug内容 使用3.6版本的tb代码进行打包生成boot的jar包,在启动的时候会报错mailConfigTemplateController bean初始化找不到文件路径。 Error creating bean with name mailConfigTemplateController defined in URL [jar:file:/D:/yuxinwei/AE/thingsboard/thingsboard-3…...

Go语言中获取IP

简介 在net包中提供了获取所有网卡的ip&#xff0c;一般不会用127.0.0.1,::1这样的本地回环地址&#xff0c;可以过滤掉&#xff0c;如果想要获取当前真正在使用的地址&#xff0c;得通过net.Dail去连一下才知道 获取ip地址 func main() {fmt.Println(getIpv4())fmt.Println…...

【Computer Vision Foundation】全球计算机视觉基金会论文网

计算机视觉基金会&#xff08;Computer Vision Foundation&#xff0c;简称CVF&#xff09;是一个致力于推动计算机视觉领域研究和发展的组织。以下是关于计算机视觉基金会的一些基本信息&#xff1a; 成立目的&#xff1a; CVF成立的目的是促进计算机视觉领域的学术研究、技术…...

计网(复习自用)

计算机网络 1.概述 1.1概念 含义 计算机网络&#xff1a;是一个将分散的。具有独立功能的计算机系统&#xff0c;通过通信设备和线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统。 简单点说&#xff0c;计算机网络是互联的&#xff0c;自治的计算机集…...

安徽省广德市选择云轴科技ZStack Cloud云平台建设县级智慧城市

信创是数字中国建设的重要组成部分&#xff0c;也是数字经济发展的关键推动力量。作为云基础软件企业&#xff0c;云轴科技ZStack产品矩阵全面覆盖数据中心云基础设施&#xff0c;ZStack信创云首批通过可信云《一云多芯IaaS平台能力要求》先进级&#xff0c;是其中唯一兼容四种…...

【计算思维】蓝桥杯STEMA 科技素养考试真题及解析 6

1、明明买了一个扫地机器人&#xff0c;可以通过以下指令控制机器人运动: F:向前走 10 个单位长度 L:原地左转 90 度 R:原地右转 90 度 机器人初始方向向右&#xff0c;需要按顺序执行以下那条指令&#xff0c;才能打扫完下图中的道路 A、F-L-F-R-F-F-R-F-L-F B、F-R-F-L-F-F…...

nuxt3项目修改端口号

nuxt的默认端口号是3000 一、修改开发环境端口号 方式一&#xff1a;使用环境变量配置,设置&#xff08;PORT 或 NUXT_PORT&#xff09; # .env PORT3001 #http://localhost:3001/ NITRO_PORT3001 #http://localhost:3001/ 方式二&#xff1a;nuxt.config.ts里配置…...

c语言中使用openssl对rsa私钥解密

单次加密数据的最大长度&#xff08;block_len&#xff09;&#xff0c;由RSA秘钥模长RSA_size()和填充模式有关 填充模式&#xff1a;RSA_PKCS1_PADDING&#xff0c; block_lenRSA_size() - 11填充模式&#xff1a;RSA_PKCS1_OAEP_PADDING&#xff0c;block_lenRSA_size() - 4…...

mysql中数据是如何被用B+树查询到的

innoDB是按照页为单位读写的 那页中有很多行数据&#xff0c;是怎么执行查询的呢&#xff0c;首先我们肯定&#xff0c;是以单向列表形式存储的&#xff0c;提高了增删的效率&#xff0c;但是查询效率低。所以实际上对页中的行数据进行了优化&#xff0c;能以二分的方式进行查…...

Redisson 分布式锁的最佳实践

Redisson 分布式锁的最佳实践 第一、添加依赖第二、添加redisson配置类第三、添加测试类测试结果扩展知识redisson锁中lock方法和tryLock方法有什么区别锁续约 注意事项 引言 在现代分布式系统中&#xff0c;处理并发问题是至关重要的。分布式锁是解决这类问题的关键工具之一。…...

ArkTS声明式开发范式

装饰器 用来装饰类、结构体、方法以及变量&#xff0c;赋予其特殊的含义&#xff0c;如上述示例中 Entry 、 Component 、 State 都是装饰器。 Component 表示这是个自定义组件&#xff1b; Entry 则表示这是个入口组件&#xff1b; State 表示组件中的状态变量&#xff0c;…...

史诗级云故障敲响警钟,应用保障不能没有“连续键”!

近日&#xff0c;知名云服务商出现一次史诗级的云故障&#xff1a;全球所有区域/所有服务同时异常&#xff0c;故障持续长达3小时之多&#xff0c;云上众多应用受到极大影响。 如今&#xff0c;在一个充满不确定性和复杂性的数字化时代&#xff0c;哪怕是顶级云服务商亦不能避…...

Obsidian Day Planner:3步打造高效可视化的日程管理系统

Obsidian Day Planner&#xff1a;3步打造高效可视化的日程管理系统 【免费下载链接】obsidian-day-planner An Obsidian plugin for day planning with a clean UI and a simple task format 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-day-planner 你是否…...

AI网站克隆模板:用LLM与无头浏览器智能解析网页结构与设计

1. 项目概述&#xff1a;一个能“克隆”网站的AI模板最近在GitHub上看到一个挺有意思的项目&#xff0c;叫JCodesMore/ai-website-cloner-template。光看名字&#xff0c;你可能觉得这又是一个普通的网页抓取工具&#xff0c;但实际接触下来&#xff0c;我发现它的定位和实现思…...

按劳分配自动分红程序,颠覆资本优先分红,劳动贡献上链,按贡献自动分配收益,人人公平。

按劳分配自动分红系统&#xff1a;基于区块链的贡献值驱动收益分配方案一、实际应用场景描述本系统适用于DAO组织、开源社区、内容创作团队等场景&#xff0c;参与者通过贡献劳动&#xff08;如代码提交、内容创作、社区运营&#xff09;获得链上记录的贡献值&#xff0c;系统按…...

ARM GICv3虚拟中断控制器架构与实现详解

1. ARM GICv3虚拟中断控制器架构概述在ARMv8-A架构的虚拟化环境中&#xff0c;GICv3&#xff08;Generic Interrupt Controller v3&#xff09;中断控制器扮演着关键角色。作为第三代通用中断控制器&#xff0c;GICv3通过硬件辅助的虚拟化扩展&#xff0c;为虚拟机提供了高效的…...

2026-04-30:交替删除操作后最后剩下的整数。用go语言,给定一个整数 n,把 1 到 n 依次排成一行。之后反复进行两种删数方式,并且这两种方式交替使用,先用第一种,再用第二种,一直持续到只剩

2026-04-30&#xff1a;交替删除操作后最后剩下的整数。用go语言&#xff0c;给定一个整数 n&#xff0c;把 1 到 n 依次排成一行。之后反复进行两种删数方式&#xff0c;并且这两种方式交替使用&#xff0c;先用第一种&#xff0c;再用第二种&#xff0c;一直持续到只剩下一个…...

喜马拉雅音频批量下载完整指南:建立你的个人离线音频库

喜马拉雅音频批量下载完整指南&#xff1a;建立你的个人离线音频库 【免费下载链接】xmly-downloader-qt5 喜马拉雅FM专辑下载器. 支持VIP与付费专辑. 使用GoQt5编写(Not Qt Binding). 项目地址: https://gitcode.com/gh_mirrors/xm/xmly-downloader-qt5 还在为喜马拉雅…...

CJITC:轻量可移植的C语言编译器,全平台适用且即时部署!

【导语&#xff1a;CJITC作为一款轻量且可移植的C语言编译器和解释器&#xff0c;具有全平台适用、即时部署等特点&#xff0c;为C语言开发带来了新的便利。】CJITC&#xff1a;源自灵感的C语言利器CJITC的灵感源自Terry Davis的HolyC&#xff0c;基于Fabrice Bellard的TinyCC开…...

Unity高性能割草游戏方案:用P3D Survivors Engine 打造爆款“类吸血鬼幸存者”游戏

一、插件简介 在近几年独立游戏市场中&#xff0c;以 Vampire Survivors 为代表的“幸存者类&#xff08;Survivors-like&#xff09;”游戏迅速爆火。这类游戏凭借爽快的割草体验、简单操作与高度可复玩性&#xff0c;成为移动端与PC端的热门赛道。 而 P3D: Survivors Engine …...

英雄联盟自动化工具:5个核心功能让你的游戏体验提升300%

英雄联盟自动化工具&#xff1a;5个核心功能让你的游戏体验提升300% 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power &#x1f680;. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 你是否厌倦了在英雄联盟中…...

【AI工程化硬核警告】:PHP 9.0正式支持Fibers原生异步,但87.6%的AI机器人因未重写Promise调度器已悄然降级为同步阻塞

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;PHP 9.0异步演进与AI机器人性能断崖的真相 PHP 9.0 并非官方已发布的版本&#xff08;截至 2024 年&#xff0c;PHP 官方最新稳定版为 8.3&#xff09;&#xff0c;但社区中广泛流传的“PHP 9.0”概念实…...