logback 自定义 Layout

还是因为日志统一管理,作为一个工具开放出去以后再Layout 中的%只能打印到日志类,无法打印到实际调用类中。上次阅读了代码【slf4j 之 ch.qos.logback 源码阅读】 。这次主要实操进行修改。

主要日志管理类:

public class RLogger {
	final static Logger log = LoggerFactory.getLogger("BUSINESS");
	final static Logger error = LoggerFactory.getLogger("ERROR");
	final static Logger debug = LoggerFactory.getLogger("DEBUGGER");
	final static Logger sys = LoggerFactory.getLogger("RSYS");

	public static void sysinfo(String mess) {
		sys.info(mess);
	}
	public static void sysinfo(String format, Object... arguments) {
		sys.info(format, arguments);
	}
	public static void sysError(String mess, Throwable t) {
		sys.error(mess, t);
		error.error(mess, t);
	}
	public static void info(String mess) {
		log.info(mess);
	}

	public static void info(String format, Object... arguments) {
		log.info(format, arguments);
	}

	public static void warn(String mess) {
		log.warn(mess);
	}

	public static void warn(String format, Object... arguments) {
		log.warn(format, arguments);
	}

	public static void debug(String mess) {
		if (debug.isDebugEnabled())
			debug.debug(mess);
	}

	public static void debug(String format, Object... arguments) {
		debug.debug(format, arguments);
	}

	public static void error(String mess, Throwable t) {
		log.info(mess);
		error.error(mess, t);
	}

	public static void error(String mess) {
		log.info(mess);
		error.error(mess);
	}

	public static boolean isDebugEnabled() {
		return debug.isDebugEnabled();
	}
}

这个类作为内置的方法别的类或者多开发者直接调用相关静态方法就行不用再每个类中声明静态logger对象。

Layout 重写

public class RLogLayout extends PatternLayout{
	public RLogLayout() {
		super();
	    defaultConverterMap.put("C", RLogClassOfCallerConverter.class.getName());
	}
}

这个很简单主要是为了修改再%C 配置时的获取调用类的类名具体实际操作是RLogClassOfCallerConverter.class

RLogClassOfCallerConverter

public class RLogClassOfCallerConverter  extends NamedConverter {

	protected String getFullyQualifiedName(ILoggingEvent event) {
	        StackTraceElement[] cda = event.getCallerData();
	        if (cda != null && cda.length > 1) {
	            return cda[1].getClassName();
	        } else {
	            return CallerData.NA;
	        }
	    }
}

这里是主要的获取调用类方法。原方法为ClassOfCallerConverter 类可以参考。

logback.xml 配置部分

	<appender name="STDOUT"
		class="ch.qos.logback.core.ConsoleAppender">
		<!-- 控制台输出的日志 的格式 -->
		<layout class="RLogLayout">
			<Pattern>
				%d{HH:mm:ss.SSS}[%thread][ %-5level] > %logger %C > %msg%n
			</Pattern>
		</layout>
	</appender>

直接再 layout 节点中指定重写的RLogLayout 即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值