字符解释:
%p:输出日志信息的优先级,即DEBUG,INFO,WARN,ERROR,FATAL,可能%和p中间还有-和数字,其中-号代表左对齐,数字代表最大5位,多余的位置用空格补齐
%d:输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:输出自应用程序启动到输出该log信息耗费的毫秒数。
%t:输出产生该日志事件的线程名。
%l:输出日志事件的发生位置,相当于%c.%M(%F:%L)的组合,包括类全名、方法、文件名以及在代码中的行数。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:输出日志信息所属的类目,通常就是所在类的全名。
%M:输出产生日志信息的方法名。
%F:输出日志消息产生时所在的文件名称。
%L::输出代码中的行号。
%m::输出代码中指定的具体日志信息。
%n:输出一个回车换行符,Windows平台为"rn",Unix平台为"n"。
%x:输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
%%:输出一个"%"字符。
测试:
1、[%-5p][%d{yyyy-MM-dd HH:mm:ss}] %c %L %m%n
答:真实环境中输出的结果是:
[FATAL][2020-03-02 17:48:02] com.bjpowernode.test.MyTest 9 fatal信息
[ERROR][2020-03-02 17:48:02] com.bjpowernode.test.MyTest 10 error信息
[WARN ][2020-03-02 17:48:02] com.bjpowernode.test.MyTest 11 warn信息
[INFO ][2020-03-02 17:48:02] com.bjpowernode.test.MyTest 12 info信息
根据上面的字符解释就可以知道什么意思