slf4j使用log4j的配置参数方式

网友投稿 583 2022-09-06


slf4j使用log4j的配置参数方式

目录slf4j使用log4j的配置参数slf4j 的 maven 配置如下关于具体的配置 log4j.properties日志级别常用的输出位置格式化输出slf4j集成log4j小结日志配置使用 Slf4j集成 log4j为什么使用slf4jslf4j集成log4j所需jar包及maven配置slf4j及log4j配置文件slf4j集成log4j

slf4j使用log4j的配置参数

slf4j,即简单日志门面(Simple Logging Facade for java),不是具体的日志解决方案,它只服务于各种各样的日志系统。

按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。

比如用户可以自己选择使用 log4j 或是 log4j2 。

slf4j 的 maven 配置如下

org.slf4j

slf4j-api

1.7.21

org.slf4j

slf4j-log4j12

1.7.21

关于具体的配置 log4j.properties

### 设置rootLogger ###

log4j.rootLogger = info,stdout,D,E

### 输出信息到控制台 ###

### 控制台输出

log4j.appender.stdout = org.apache.log4j.ConsoleAppender

### 默认是system.out,如果system.err是红色提示

log4j.appender.stdout.Target = System.out

### 布局格式,可以灵活指定

log4j.appender.stdout.layout = org.apache.log4j.PatternLayout

### 消息格式化

log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n

### 输出INFO 级别以上的日志到=D://logs/error.log ###

### 以每天一个文件输出日志

log4j.appender.D = org.apache.log4j.DailyRollingFileAppender

### 输出文件目录

log4j.appender.D.File = D://logs/log.log

### 消息增加到指定的文件中,false表示覆盖指定文件内容

log4j.appender.D.Append = true

### 输出信息最低级别

log4j.appender.D.Threshold = INFO

log4j.appender.D.layout = org.apache.log4j.PatternLayout

log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n

### 输出ERROR 级别以上的日志到=D://logs/error.log ###

log4j.appender.E = org.apache.log4j.DailyRollingFileAppender

log4j.appender.E.File =D://logs/error.log

log4j.appender.E.Append = true

log4j.appender.E.Threshold = ERROR

log4j.appender.E.layout = org.apache.log4j.PatternLayout

log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n

日志级别

主要有以下:

ERROR 错误

WARN 警告

INFO 一般信息

DEBUG 调试信息

常用的输出位置

ConsoleAppender 控制台

FileAppender 文件

DailyRollingFileAppender 每天产生一个日志文件

RollingFileAppender 文件大小达到指定尺寸时产生一个新文件

WriterAppeder 将日志信息以流格式发送到指定地方

格式化输出

-X号: X信息输出时左对齐;

%p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,

%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921

%r: 输出自应用启动到输出该log信息耗费的毫秒数

%c: 输出日志信息所属的类目,通常就是所在类的全名

%t: 输出产生该日志事件的线程名

%l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java:10)

%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像Java servlets这样的多客户多线程的应用中。

%%: 输出一个”%”字符

%F: 输出日志消息产生时所在的文件名称

%L: 输出代码中的行号

%m: 输出代码中指定的消息,产生的日志具体信息

有时我们看到 %-5p 或者 %5p 意思就是输出日志级别时,左对齐或右对齐,4个字母的 INFO / WARN 要补一个空格,才能和 DEBUG / ERROR 对齐格式。

slf4j集成log4j小结

日志配置使用 Slf4j集成 log4j

为什么使用slf4j

slf4j集成log4j所需jar包及maven配置

slf4j及log4j配置文件

slf4j集成log4j示例

为什么使用slf4j

SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。通过示例说明该特性:

public class App {

final Logger logger = LoggerFactory.getLogger(App.class);

private void test() {

logger.info("这是一条日志信息 - {}", "mafly");

}

public static void main(String[] args) {

App app = new App();

app.test();

System.out.println("Hello World!");

}

}

对于不同的日志系统而言只需增加slf4j依赖包

org.slf4j

slf4j-api

1.7.22

对于使用logback日志系统用户而言 配置

ch.qos.logback

logback-core

1.1.9

ch.qos.logback

logback-classic

1.1.9

同时配置logback.xml的配置文件,即可使用slf4j管理日志系统,同时如果想要切换日志系统,例如 想要切换到log4j,无需修改代码,只需将上述logback dependency删除,增加log4j的配置

org.slf4j

slf4j-log4j12

1.7.21

log4j

log4j

1.2.17

可以实现不修改代码,更改日志系统的功能。

slf4j集成log4j所需jar包及maven配置

org.slf4j

slf4j-api

1.7.21

org.slf4j

slf4j-log4j12

1.7.21

log4j

log4j

1.2.17

所需外部支持可分为三部分:slf4j-api包 log4j包 以及slf4j-log4j12guanlainbao

slf4j及log4j配置文件

在 src/main/resources中 new–>resource bundle —->写入文件名 log4j 生成log4j.properties文件

### config root logger

log4j.rootLogger=info, STDOUT

配置根logger 格式为 [level],appenderName1,appenderName2……

其中[level]共分为5级,如下:

FATAL 0

ERROR 3

WARN 4

INFO 6

DEBUG 7

appendername是配置日志输出的目的地

log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender

log4j.appender.STDOUT.Target=System.out

log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout

log4j.appender.STDOUT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n

其中appender的类型有如下几种:

org.apache.log4j.ConsoleAppender(控制台),

org.apache.log4j.FileAppender(文件),

org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),

org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

输出格式layout有如下几种

org.apache.log4j.HTMLLayout(以HTML表格形式布局),

org.apache.log4j.PatternLayout(可以灵活地指定布局模式),

org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),

org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

打印参数配置如下:

%m 输出代码中指定的消息

%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL

%r 输出自应用启动到输出该log信息耗费的毫秒数

%c 输出所属的类目,通常就是所在类的全名

%t 输出产生该日志事件的线程名

%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”

%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日 22 : 10 : 28 , 921

%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java: 10 )

输出到文件中示例:

### 输出到日志文件 ###

log4j.appender.D = org.apache.log4j.DailyRollingFileAppender

log4j.appender.D.File = logs/log.log

log4j.appender.D.Append = true

log4jhttp://.appender.D.Threshold = DEBUG ## 输出DEBUG级别以上的日志

log4j.appender.D.layout = org.apache.log4j.PatternLayout

log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n

slf4j集成log4j

约定大于配置,如果将log4j.properties放置在classpath中,即resources文件夹下 可自动读取

private static final Logger logger= LoggerFactory.getLogger(TestUtil.class);

public static void main(String [] args){

logger.info("info信息");

logger.debug("debug信息");

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:效率倍增,推荐10个好用到爆的Jupyter Notebook插件(效率蛮高的)
下一篇:【面试招聘】不要忽视实习面试失败对校招的影响
相关文章

 发表评论

暂时没有评论,来抢沙发吧~