Log4j2 自定义 Appender

本文介绍了如何在Log4j2中自定义Appender,以满足特定的日志输出需求。当Log4j2自带的Appender无法满足业务场景时,可以通过实现AbstractAppender和AbstractManager来自定义。在编码完成后,配置文件需要添加自定义Appender,但可能会遇到CLASS_NOT_FOUND错误。文章还分享了一个人工智能教程链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

               

虽然log4j2 自带了很多种Appender 但是有时候避免不了不是自己想要的,这时候我们就需要自定义Appender,使日志输出到我们指定的位置,废话少说,上菜!

 

package com.hbzx.log;import java.io.Serializable;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReadWriteLock;import java.util.concurrent.locks.ReentrantReadWriteLock;import org.apache.logging.log4j.core.Filter;import org.apache.logging.log4j.core.Layout;import org.apache.logging.log4j.core.LogEvent;import org.apache.logging.log4j.core.appender.AbstractAppender;import org.apache.logging.log4j.core.appender.AppenderLoggingException;import org.apache.logging.log4j.core.config.plugins.Plugin;import org.apache.logging.log4j.core.config.plugins.PluginAttribute;import org.apache.logging.log4j.core.config.plugins.PluginElement;import org.apache.logging.log4j.core.config.plugins.PluginFactory;import org.apache.logging.log4j.core.layout.PatternLayout;import com.hbzx.frame.MainFrame;/** * 自定义Appender,继承 AbstractAppender 只需要覆盖自已想要的方法即可<br> * 类上面的注解是用来设置配置文件中的标签。 */@Plugin(name = "TextArea", category = "Core", elementType = "appender", printObject = true)public class TextAreaAppender extends AbstractAppender {    /**     * @fields serialVersionUID     */    private static final long serialVersionUID = -830237775522429777L;    private final ReadWriteLock rwLock = new ReentrantReadWriteLock();    private final Lock readLock = rwLock.readLock();    //需要实现的构造方法,直接使用父类就行    protected TextAreaAppender(final String name, final Filter filter, final Layout<? extends Serializable> layout,            final boolean ignoreExceptions)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值