一个服务器可以放多少网站,深圳住房和建设局网站哪里预约,网站建设需要,基于php网站开发logback
1、logback介绍
Logback是由log4j创始人设计的另一个开源日志组件#xff0c;性能比log4j要好。
lockback优点#xff1a;
内核重写、测试充分、初始化内存加载更小#xff0c;这一切让logback性能和log4j相比有诸多倍的提升。logback非常自然地直接实现了slf4j…logback
1、logback介绍
Logback是由log4j创始人设计的另一个开源日志组件性能比log4j要好。
lockback优点
内核重写、测试充分、初始化内存加载更小这一切让logback性能和log4j相比有诸多倍的提升。logback非常自然地直接实现了slf4j这个严格来说算不上优点只是这样再理解slf4j的前提下会很容易理解logback也同时很容易用其他日志框架替换logback。logback有比较齐全的200多页的文档。logback当配置文件修改了支持自动重新加载配置文件扫描过程快且安全它并不需要另外创建一个扫描线程。支持自动去除旧的日志文件可以控制已经产生日志文件的最大数量。
1.1 lockback模块
logback-core其他两个模块的基础模块
logback-classic它是log4j的改良版本完整实现了SIf4j API
logback-access访问模块与servlet容器继承提供通过Http来访问日志的功能
想要使用lockback日志框架至少需要在项目中整合下面三个模块 slf4j-api日志接口、lockback-core、logback-classic
1.2 lockback组件
1 Logger日志的记录器把它关联到应用的对应的context上后主要用于存放日志对象也可以定义日志类型、级别。
2 Appender用于指定日志输出的目的地可以是控制台、文件、数据库等等。
3 Layout负责把事件转换成字符串格式化的日志信息的输出。在logback中Layout对象被封装在encoder中。
1.3 lockback配置
logback会依次读取以下类型配置文件
1 logback.grovy
2 logback-test.xml
3 logback.xml
1.4 lockback.xml配置文件解析
?xml version1.0 encodingUTF-8?configuration!-- 配置集中管理属性可以直接使用该属性的值格式${name} --property namepattern value[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} %c %M %L [%thread] %m%n/!-- 日志输出格式%-5level : 级别从左显示5个字符宽度%d : 日期%c : 类的完整名称%M : 方法名%L : 行号%thread : 线程名称%m : 信息%n : 换行 --!-- 格式化输出%d表示日期 %thread表示线程名%-5level级别从左显示5个字符宽度 %msg日志消息 %n是换行符 --!-- 控制台日志输出的appender --!-- 每个标签的编写都是使用类的set方法如target标签对应setTarget方法 --appender nameconsole classch.qos.logback.core.ConsoleAppender!-- 控制输出流对象默认是System.out可以改为System.err区别在于字体颜色不同 --targetSystem.err/target!-- 日志消息格式配置 --encoder classch.qos.logback.classic.encoder.PatternLayoutEncoderpattern${pattern}/pattern/encoder/appender!-- 文件输出的appender --appender namefile classch.qos.logback.core.FileAppenderfilepath/to/log/file.log/file!-- 日志文件拆分规则 --rollingPolicy classch.qos.logback.core.rolling.TimeBasedRollingPolicy!-- 文件名模式按日期拆分保留最近7天的日志文件 --fileNamePatternpath/to/log/file-%d{yyyy-MM-dd}.%i.log.gz/fileNamePatternmaxHistory7/maxHistory/rollingPolicy!-- 触发拆分的条件按文件大小拆分当日志文件大小达到10MB时触发拆分 --triggeringPolicy classch.qos.logback.core.rolling.SizeBasedTriggeringPolicymaxFileSize10MB/maxFileSize/triggeringPolicy!-- 日志消息格式配置 --encoder classch.qos.logback.classic.encoder.PatternLayoutEncoderpattern${pattern}/pattern/encoder/appender!-- root logger配置只有日志的级别是大于或等于核心配置文件配置的日志级别才会被记录否则不记录。 --root levelALL!--TRACE追踪: 提供比DEBUG更详细的信息用于追踪代码执行流程。DEBUG调试: 用于调试应用程序提供详细的信息通常不应该在生产环境中启用。INFO信息: 提供一般性的信息用于说明应用程序的运行状态如启动、关闭等。WARN警告: 表示潜在的问题不会导致应用程序停止运行但需要引起注意。ERROR错误: 用于表示错误事件可能导致应用程序无法正常执行。OFF关闭: 用于关闭所有日志记录。ALL所有: 记录所有的日志消息。--!-- 引用控制台和文件输出的appender,想输出到哪里就加哪个 --appender-ref refconsole/appender-ref reffile//root/configuration
2、lockback快速入门
需求使用Logback日志框架纪录系统的运行信息。
实现步骤
导入Logback框架到项目中去。 slf4j-api日志接口、lockback-core、logback-classic将Logback框架的核心配置文件logback.xml直接拷贝到src目录下必须是Src下创建Logback框架提供的Logger对象然后用Logger对象调用其提供的方法就可以记录系统的日志信息。
public static final Logger LOGGER LoggerFactory.getLogger类名;