PatternLayoutEncoder

ch.qos.logback.classic.encoder.PatternLayoutEncoder

ch.qos.logback.classic.PatternLayout

ch.qos.logback.core.pattern.PatternLayoutBase

PatternLayoutBase.class 代码片段,入口

public void start() {
    if(pattern == null || pattern.length() == 0) {
      addError("Empty or null pattern.");
      return;
    }
    try {
      Parser<E> p = new Parser<E>(pattern);
      if (getContext() != null) {
        p.setContext(getContext());
      }
      Node t = p.parse();
      this.head = p.compile(t, getEffectiveConverterMap());
      if (postCompileProcessor != null) {
        postCompileProcessor.process(head);
      }
      ConverterUtil.setContextForConverters(getContext(), head);
      ConverterUtil.startConverters(this.head);
      super.start();
    } catch (ScanException sce) {
      StatusManager sm = getContext().getStatusManager();
      sm.add(new ErrorStatus("Failed to parse pattern \"" + getPattern()
          + "\".", this, sce));
    }
  }

<pattern> </pattern> 内容结构

... + Token.PERCENT + Token.FORMAT_MODIFIER + Token.SIMPLE_KEYWORD + Token.OPTION + ...

例如:
%-5level
%logger{36}

... 代表 任意多个Token.LITERAL 或者 自身

oken.PERCENT 是 %
Token.FORMAT_MODIFIER 必须是数字,正数代表当前位置(即文本左侧)填充空格,负数代表当前位置相反方向填充空格,数值代表“填充空格至N个字符”,字符串本身长度大于等于N时,不需要填充。

Token.SIMPLE_KEYWORD 是PatternLayout 中定义的字符(对应各自的Converter类)

Token.OPTION 是由第一个“{”开启,第一个“}”结束,例如:
%logger{36}} 中的第二个“}”视为 Token.LITERAL 普通文本
传递多个参数用英文“,”分割,例如:
{opt1,opt2}

Converter 详解

http://logback.qos.ch/manual/layouts.html#conversionWord

1. d/date

DateConverter.class

%date{}                                  yyyy-MM-dd HH:mm:ss,SSS

%date{ISO8601}                      yyyy-MM-dd HH:mm:ss,SSS

%date{SimpleDateFormat}         SimpleDateFormat

2. r/relative

3. level/le/p

级别名称 TRACE  DEBUG  INFO  WARN  ERROR

4. t/thread

线程名称

5. lo/logger/c

loggerName

Logger org.slf4j.LoggerFactory.getLogger(Class clazz)

clazz的全限定名称

例如:cn.zno.SomeClazz

6. m/msg/message

FormattedMessage

void org.slf4j.Logger.trace(String format, Object... arguments)

由{} 开启参数,有Object[] 设置参数

例如:

        String s = "sdfsdf";
        int i = 111;
        double d = 22.0;
        Date date = new Date();
        logger.trace("It is trace{}&{}&{}&{}",s,i,d,date);

打印:

It is tracesdfsdf&111&22.0&Wed Sep 09 09:35:55 CST 2015 

7. C/class

logger 位于的类名

8. M/method

打印本次log的直接方法名

9. L/line

logger调用打印方法的位置(.java文件中)

10.F/file

该logger位于哪个.java文件

11. X/mdc

Mapped Diagnostic Contexts (MDC)

映射 诊断 上下文

12. 等等

时间: 2024-12-18 15:40:14

PatternLayoutEncoder的相关文章

Spring Boot开发之流水无情(二)

上篇散仙写了一个很简单的入门级的Spring Boot的例子,没啥技术含量,不过,其实学任何东西只要找到第一个突破口,接下来的事情就好办了,人最怕什么? 我想莫过于干一件事情,没有下手的地方了,而当你一旦找到了这感觉,就可以很喜悦的顺藤摸瓜般的探索你强烈想探索求知的某种事物了,这种冥冥之中玄而又玄的感觉是什么?回想一下: (1) 当你把第一个某种编程语言的Hello World的例子,成功的运行在一个IDE中  (2) 当你第一次从老家出发到达了某个你从未涉足过的地方  (3) 当你成功的完成了

logback logback.xml 常用配置详解

一:根节点 包含的属性: scan: 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true. scanPeriod: 设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒.当scan为true时,此属性生效.默认的时间间隔为1分钟. debug: 当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态.默认值为false. 例如: <configuration scan="true" scan

logback只输出WARN级别的日志

<appender name="compare" class="ch.qos.logback.core.rolling.RollingFileAppender"> <File>${catalina.base}/logs/sec-firewall_compare.log</File> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder

logback与Spring、SpringMVC结合使用教程

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要介绍了如何在spring.springMVC中使用logback 一.logback与Spirng结合使用 1.maven添加引用: <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.versio

【Spring】Spring的定时任务

> 参考的优秀文章 Task Execution and Scheduling > 版本说明 <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>3.2.14.RELEASE</version> </dependen

logback备注

<?xmlversion="1.0"encoding="UTF-8"?> <!-- <configuration>包含的属性 scan: 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true. scanPeriod: 设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒.当scan为true时,此属性生效.默认的时间间隔为1分钟. debug: 当此属性设置为true时,将打印出logb

Java日志:集成slf4j和logback

Java日志方案有很多,包括:java.util.logging.Apache的commons-logging和log4j.slf4j以及logback. 一个大型项目会用到众多第三方jar包,这些jar包可能会用到上述各种日志方案,如何在新的项目中使用slf4j+logback的组合,让所有其他jar包的日志也输出到logback,并避免冲突和异常? SLF4J is a simple facade for logging systems allowing the end-user to pl

java程序日志管理

初入软件开发这一行的人,可能对日志管理的概念并不是很明确,大概是由于经验所限,以至于根本还考虑不到这个问题. 而从某种意义上来说,日志管理实际上也不需要初入这一行的人来管,他们只需要负责实现自己的主要业务逻辑和功能就好了. 我当初刚入行的时候就有很长一段时间完全不用去关心日志,到后来偶尔涉及到的时候,也都是从其他地方采用cv大法直接搬用. 不过,随着工作时间的变化,随着手头上任务重要程度的变化,也随着接触到的项目数量的变化,让我越来越意识到日志的重要性,它在整个系统中发挥着至关重要的作用! 尤其

logback 配置详解

一:根节点<configuration>包含的属性: scan: 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true. scanPeriod: 设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒.当scan为true时,此属性生效.默认的时间间隔为1分钟. debug: 当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态.默认值为false. 例如 1 <configuration scan=