搞这个玩意儿,不是特别好啊。为啥不能有好过度,玩儿死程序猿么。
##111
Why? 优点请参考这里的文:从Log4j迁移到LogBack的理由
英文原文:Reasons to prefer logback over log4j
##111
参考配置:from:http://yuri-liuyu.iteye.com/blog/954038
新的公司日志管理统一用logback,由于之前一直在用log4j,所以其实对logback这个由log4j长出来的家伙还不算陌生。
首先介绍下logback的前世今生。
slf4j由log4j作者Ceki开发,逐步取代apahce commons logging。
logback由log4j作者Ceki开发,逐步取代log4j。
slf4j等于commons-logging,是各种日志实现的通用入口,会根据classpath中存在下面哪一个Jar来决定具体的日志实现库。
logback相比较log4j的优势
slf4j支持参数化的logger.error("帐号ID:{}不存在", userId);
告别了if(logger.isDebugEnable()) 时代。
另外logback的整体性能比log4j也较佳,hibernate等项目已经采用了slf4j。
slf4j和logback的使用
1.如果日志的参数超过3个,需要写成
- Object[] params = {newVal, below, above};
- logger.debug("Value {} was inserted between {} and {}.", params);
2.因为内部已优化,作者认为slf4j的logger不需要定义为static。
3.可设置缓存后批量写日志文件(但服务器如果重启,可能会丢失未写到磁盘的记录)
4.MDC,用Filter,将当前用户名等业务信息放入MDC中,在日志format定义中即可使用该变量。
5.JMS Appender用于告警, DB Appender用于业务日志等可以使用插件,如生成Log代码的Eclipse插件Log4E。
6.tomcat和glassfish中,设定日志路径为../logs/xxxx.log 都能将日志放入应用服务器本身的logs目录。
最后把最近完善的一个logback.xml贴上,毕竟实际项目中的文件最能说明问题。
- <?xml version="1.0" encoding="UTF-8"?>
- <configuration>
- <substitutionProperty name="log.base" value="d:\\logback\\logback" />
- <jmxConfigurator />
- <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator name="myEval">
- <expression>message.contains("dao")</expression>
- </evaluator>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- <layout class="ch.qos.logback.classic.PatternLayout">
- <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
- </layout>
- </appender>
- <appender name="logfile-dao"
- class="ch.qos.logback.core.rolling.RollingFileAppender">
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator name="myEval_dao">
- <expression>message.contains("dao")</expression>
- </evaluator>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- <Encoding>UTF-8</Encoding>
- <File>${log.base}_dao.log</File>
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
- <FileNamePattern>${log.base}.%d{yyyy-MM-dd}_dao.log.zip
- </FileNamePattern>
- </rollingPolicy>
- <layout class="ch.qos.logback.classic.PatternLayout">
- <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
- </layout>
- </appender>
- <appender name="logfile-service"
- class="ch.qos.logback.core.rolling.RollingFileAppender">
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator name="myEval_service">
- <expression>message.contains("service.impl")</expression>
- </evaluator>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- <Encoding>UTF-8</Encoding>
- <File>${log.base}_service.log</File>
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
- <FileNamePattern>${log.base}.%d{yyyy-MM-dd}_service.log.zip
- </FileNamePattern>
- </rollingPolicy>
- <layout class="ch.qos.logback.classic.PatternLayout">
- <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
- </layout>
- </appender>
- <appender name="jms_dao" class="ch.qos.logback.classic.net.JMSQueueAppender">
- <InitialContextFactoryName>
- org.apache.activemq.jndi.ActiveMQInitialContextFactory
- </InitialContextFactoryName>
- <ProviderURL>tcp://192.168.1.120:61616</ProviderURL>
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator name="myEval_service">
- <expression>message.contains("dao")</expression>
- </evaluator>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- <QueueConnectionFactoryBindingName>ConnectionFactory
- </QueueConnectionFactoryBindingName>
- <QueueBindingName>cms_dao_log</QueueBindingName>
- </appender>
- <appender name="jms_service" class="ch.qos.logback.classic.net.JMSQueueAppender">
- <InitialContextFactoryName>
- org.apache.activemq.jndi.ActiveMQInitialContextFactory
- </InitialContextFactoryName>
- <ProviderURL>tcp://192.168.1.120:61616</ProviderURL>
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator name="myEval_service">
- <expression>message.contains("service.impl")</expression>
- </evaluator>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- <QueueConnectionFactoryBindingName>ConnectionFactory
- </QueueConnectionFactoryBindingName>
- <QueueBindingName>cms_service_log</QueueBindingName>
- </appender>
- <logger name="com.cms5.cmsservice.jms">
- <level value="DEBUG" />
- </logger>
- <logger name="java.sql.PreparedStatement">
- <level value="DEBUG" />
- </logger>
- <logger name="java.sql.Connection">
- <level value="DEBUG" />
- </logger>
- <logger name="java.sql.Statement">
- <level value="DEBUG" />
- </logger>
- <logger name="com.ibatis">
- <level value="DEBUG" />
- </logger>
- <logger name="com.ibatis.common.jdbc.SimpleDataSource">
- <level value="DEBUG" />
- </logger>
- <logger name="com.ibatis.common.jdbc.ScriptRunner">
- <level value="DEBUG" />
- </logger>
- <logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate">
- <level value="DEBUG" />
- </logger>
- <logger name="com.danga.MemCached">
- <level value="INFO" />
- </logger>
- <logger name="org.springframework.test">
- <level value="DEBUG" />
- </logger>
- <logger name="org.apache.struts2">
- <level value="DEBUG" />
- </logger>
- <root>
- <level value="INFO" />
- <!--<appender-ref ref="stdout" />
- -->
- <appender-ref ref="logfile-dao" />
- <appender-ref ref="logfile-service" />
- <appender-ref ref="jms_dao" />
- <appender-ref ref="jms_service" />
- </root>
- </configuration>
就先不做说明了,里面的配置还是比较明确的,关于jmsappender那部分,之前也做过简单说明。
##111 From: http://www.cnblogs.com/yongze103/archive/2012/05/05/2484753.html
Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。
2、Logback的核心对象:Logger、Appender、Layout
Logback主要建立于Logger、Appender 和 Layout 这三个类之上。
Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也可以定义日志类型、级别。Logger对象一般多定义为静态常量,如:
1 package com.logs; 2 3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5 6 public class MyApp { 7 final static Logger logger = LoggerFactory.getLogger("MyApp.class"); 8 public static void main(String[] args) { 9 10 logger.trace("trace"); 11 logger.debug("debug str"); 12 logger.info("info str"); 13 logger.warn("warn"); 14 logger.error("error"); 15 } 16 }
Appender:用于指定日志输出的目的地,目的地可以是控制台、文件、远程套接字服务器、 MySQL、 PostreSQL、Oracle和其他数据库、 JMS和远程UNIX Syslog守护进程等。
Layout:负责把事件转换成字符串,格式化的日志信息的输出。具体的Layout通配符,可以直接查看帮助文档。
3、Level 有效级别
Logger可以被分配级别。级别包括:TRACE、DEBUG、INFO、WARN和ERROR,定义于ch.qos.logback.classic.Level类。程序会打印高于或等于所设置级别的日志,设置的日志等级越高,打印出来的日志就越少。如果设置级别为INFO,则优先级高于等于INFO级别(如:INFO、 WARN、ERROR)的日志信息将可以被输出,小于该级别的如DEBUG将不会被输出。为确保所有logger都能够最终继承一个级别,根logger总是有级别,默认情况下,这个级别是DEBUG。
4、 三值逻辑
Logback的过滤器基于三值逻辑(ternary logic),允许把它们组装或成链,从而组成任意的复合过滤策略。过滤器很大程度上受到Linux的iptables启发。这里的所谓三值逻辑是说,过滤器的返回值只能是ACCEPT、DENY和NEUTRAL的其中一个。
如果返回DENY,那么记录事件立即被抛弃,不再经过剩余过滤器;
如果返回NEUTRAL,那么有序列表里的下一个过滤器会接着处理记录事件;
如果返回ACCEPT,那么记录事件被立即处理,不再经过剩余过滤器。
5、Filter 过滤器
Logback-classic提供两种类型的过滤器:常规过滤器和TuroboFilter过滤器。Logback整体流程:Logger 产生日志信息;Layout修饰这条msg的显示格式;Filter过滤显示的内容;Appender具体的显示,即保存这日志信息的地方。
6、具体使用案例
Java项目中一般都会应用比如struts、spring、hibernate等开源框架,而这些框架很多是应用log4j记录日志的,所以我们考虑用log4j + slf4j + logback 。这样我们需要导入log4j-over-slf4j-1.6.4.jar 、logback-classic-1.0.1.jar 、logback-core-1.0.1.jar 、slf4j-api-1.6.4.jar ,如果你要用到EvaluatorFilter过滤器来过滤日志Msg中的特殊字符需要导入其依赖包 janino-2.3.2.jar。其logback.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <configuration> 3 4 <!-- 控制台输出 --> 5 <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"> 6 <encoder> 7 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern> 8 </encoder> 9 </appender> 10 11 <!-- 时间滚动输出 level为 DEBUG 日志 --> 12 <appender name="file—debug" 13 class="ch.qos.logback.core.rolling.RollingFileAppender"> 14 <filter class="ch.qos.logback.classic.filter.LevelFilter"> 15 <level>DEBUG</level> 16 <onMatch>ACCEPT</onMatch> 17 <onMismatch>DENY </onMismatch> 18 </filter> 19 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> 20 <FileNamePattern>D:/logs/debug.%d{yyyy-MM-dd}.log</FileNamePattern> 21 <MaxHistory>30</MaxHistory> 22 </rollingPolicy> 23 <encoder> 24 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern> 25 </encoder> 26 </appender> 27 28 <!-- 时间滚动输出 level为 ERROR 日志 --> 29 <appender name="file—error" 30 class="ch.qos.logback.core.rolling.RollingFileAppender"> 31 <filter class="ch.qos.logback.classic.filter.LevelFilter"> 32 <level>ERROR</level> 33 <onMatch>ACCEPT</onMatch> 34 <onMismatch>DENY </onMismatch> 35 </filter> 36 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> 37 <FileNamePattern>D:/logs/error.%d{yyyy-MM-dd}.log</FileNamePattern> 38 <MaxHistory>30</MaxHistory> 39 </rollingPolicy> 40 <encoder> 41 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern> 42 </encoder> 43 </appender> 44 45 <!-- 特定过滤含有某字符串的日志 --> 46 <appender name="file-str" 47 class="ch.qos.logback.core.rolling.RollingFileAppender"> 48 <filter class="ch.qos.logback.core.filter.EvaluatorFilter"> 49 <evaluator> 50 <expression>message.contains("str")</expression> 51 </evaluator> 52 <onMatch>ACCEPT</onMatch> 53 <onMismatch>DENY</onMismatch> 54 </filter> 55 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> 56 <FileNamePattern>D:/logs/contains.%d{yyyy-MM-dd}.log 57 </FileNamePattern> 58 <MaxHistory>30</MaxHistory> 59 </rollingPolicy> 60 <encoder> 61 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern> 62 </encoder> 63 </appender> 64 65 <!-- 数据库输出 --> 66 <appender name="db" class="ch.qos.logback.classic.db.DBAppender"> 67 <connectionSource 68 class="ch.qos.logback.core.db.DriverManagerConnectionSource"> 69 <driverClass>com.mysql.jdbc.Driver</driverClass> 70 <url>jdbc:mysql://host_name:3306/datebase_name</url> 71 <user>username</user> 72 <password>password</password> 73 </connectionSource> 74 </appender> 75 76 <logger name="java.sql.Connection"> 77 <level value="DEBUG" /> 78 </logger> 79 <logger name="java.sql.Statement"> 80 <level value="DEBUG" /> 81 </logger> 82 <logger name="com.ibatis"> 83 <level value="DEBUG" /> 84 </logger> 85 <logger name="com.ibatis.common.jdbc.SimpleDataSource"> 86 <level value="DEBUG" /> 87 </logger> 88 <logger name="com.ibatis.common.jdbc.ScriptRunner"> 89 <level value="DEBUG" /> 90 </logger> 91 <logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate"> 92 <level value="DEBUG" /> 93 </logger> 94 <logger name="com.danga.MemCached"> 95 <level value="INFO" /> 96 </logger> 97 <logger name="org.springframework.test"> 98 <level value="DEBUG" /> 99 </logger> 100 <logger name="org.apache.struts2"> 101 <level value="DEBUG" /> 102 </logger> 103 104 <root level="DEBUG"> 105 <appender-ref ref="stdout" /> 106 <appender-ref ref="file—debug" /> 107 <appender-ref ref="file—error" /> 108 <appender-ref ref="file-str" /> 109 <appender-ref ref="db" /> 110 </root> 111 112 </configuration>
相关推荐
"logback-slf4j日志配置文件下载即可使用" logback-slf4j是Java领域中一种常用的日志记录解决方案,它通过结合slf4j(Simple Logging Facade for Java)来提供了异步日志输出的功能,能够将日志输出到不同的文件中...
赠送jar包:logback-classic-1.2.10.jar; 赠送原API文档:logback-classic-1.2.10-javadoc.jar; 赠送源代码:logback-classic-1.2.10-sources.jar; 赠送Maven依赖信息文件:logback-classic-1.2.10.pom; 包含...
赠送jar包:logback-classic-1.2.3.jar; 赠送原API文档:logback-classic-1.2.3-javadoc.jar; 赠送源代码:logback-classic-1.2.3-sources.jar; 包含翻译后的API文档:logback-classic-1.2.3-javadoc-API文档-...
logback-classic-1.2.3.jar
标题中的“10 reasons to use logback”是一个讨论日志框架选择的主题,它提出了使用logback而非其他日志工具(如log4j)的十个理由。logback是log4j的作者Ceki Gülcü创建的一个更现代、性能更优的日志框架。在...
logback-classic-1.2.11.jar
https://github.com/qos-ch/logback-extensions/wiki/Spring https://github.com/qos-ch/logback-extensions/tree/master/spring/src/main/java/ch/qos/logback/ext/spring/web 你也可以自己用maven去下载。 注意:...
logback-core-1.2.11.jar
赠送jar包:logback-classic-1.2.6.jar; 赠送原API文档:logback-classic-1.2.6-javadoc.jar; 赠送源代码:logback-classic-1.2.6-sources.jar; 赠送Maven依赖信息文件:logback-classic-1.2.6.pom; 包含翻译后...
janino-2.3.17.jar jcl-over-slf4j-1.6.1.jar log4j-1.2.8.jar logback-access-0.9.24.jar logback-classic-0.9.24.jar logback-core-0.9.24.jar ... slf4j-1.6.1+logback-0.9.24.rar slf4j-api-1.6.1.jar
logback-cfca-jdk1.6-3.1.0.0.jar
logback-classic-1.1.2.jar 资源共享,有需要其他jar包的可以在评论留言,看到后我会陆续上传。
赠送jar包:logback-core-1.2.3.jar; 赠送原API文档:logback-core-1.2.3-javadoc.jar; 赠送源代码:logback-core-1.2.3-sources.jar; 赠送Maven依赖信息文件:logback-core-1.2.3.pom; 包含翻译后的API文档:...
赠送jar包:logback-classic-1.2.3.jar; 赠送原API文档:logback-classic-1.2.3-javadoc.jar; 赠送源代码:logback-classic-1.2.3-sources.jar; 赠送Maven依赖信息文件:logback-classic-1.2.3.pom; 包含翻译后...
本文将详细介绍如何在Spring框架中使用Logback来替代Log4j,并提供编译后的`logback-ext-spring-0.1.2-SNAPSHOT.jar`包供参考。 1. **Logback简介** Logback是由Ceki Gülcü(Log4j的创始人)创建的日志框架,...
`logback-android`是专为Android平台设计的一个高效、通用且灵活的日志框架,它基于Java社区的著名日志解决方案Logback,旨在提供比原生Android `Log`类更强大的功能和更丰富的日志管理体验。 ### 1. logback-...
logback-core-1.2.9.jar
2. logback-classic.jar:Logback的经典实现,提供了Log4j兼容的API。 3. logback-core.jar:Logback的核心库,负责日志事件的处理和输出。 4. log4j-xxx.jar:可能是一个旧版的Log4j实现,有时为了兼容遗留代码或者...
赠送jar包:logback-core-1.2.10.jar; 赠送原API文档:logback-core-1.2.10-javadoc.jar; 赠送源代码:logback-core-1.2.10-sources.jar; 赠送Maven依赖信息文件:logback-core-1.2.10.pom; 包含翻译后的API文档...
赠送jar包:logback-classic-1.2.10.jar; 赠送原API文档:logback-classic-1.2.10-javadoc.jar; 赠送源代码:logback-classic-1.2.10-sources.jar; 赠送Maven依赖信息文件:logback-classic-1.2.10.pom; 包含...