使用日志框架可以记录一个程序运行的过程和详情,同时便捷地存储到文件里面,并且性能和灵活性都比较好。
日志的体系结构包括两类日志规范接口:
- Commons Logging,简称:JCL;
- Simple Logging Facade for Java,简称:slf4j。
第三方已经做好一些日志记录实现代码,可以直接拿来用的一些日志实现框架:Log4j、JUL(java.util.loggiing)、Logback等。这里主要使用的是Logback。
LogBack的简单介绍
官方网站☞ https
Logback是由log4j创始人设计的另一个开源日志组件,基于slf4j的日志规范实现的框架,性能比log4j要好。
Logback主要分为三个技术模块:
logback-core:该模块为其他两个模块奠定了基础。
logback-classic:是log4j的一个改良版本,同时它完整实现了slf4j API。
logback-access 模块与 Tomcat 和 Jetty 等 Servlet 容器集成,以提供 HTTP 访问日志功能。
如何使用
- step1:在项目下面创建lib文件夹,将Logback的相关jar包放到该文件夹下。添加到项目依赖库中。
- step2:将Logback的核心配置文件logback.xml放到src目录下。Logback日志系统的特性都是通过核心配置文件logback.xml控制的,下面链接分享了文件。
部分日志文件说明:CONSOLE :表示当前的日志信息是输出到控制台的标志,File是输出到文件的标志。
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> <!--输出流对象 默认 System.out 改为 System.err 变红色--> <target>System.out</target> <encoder> <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %msg:日志消息,%n是换行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5level] %c [%thread] : %msg%n</pattern> </encoder> </appender>
level:用来设置打印级别,TRACE, DEBUG(默认), INFO, WARN, ERROR ;ALL 和 OFF控制是否打印日志信息。我们通过设置日志的输出级别来控制哪些日志信息输出或者不输出。
ref:控制打印位置。
<root level="ALL"> <!-- 注意:如果这里不配置关联打印位置,该位置将不会记录日志--> <appender-ref ref="CONSOLE" /> <appender-ref ref="FILE" /> </root>
- step3:代码中获取日志的对象,LOGGER调用其方法输出日志信息。通过设置好核心配置文件就可以输出到你的文件夹中了。
//创建日志对象 public static final Logger LOGGER = LoggerFactory.getLogger("tese.class"); public static void main(String[] args) { try { LOGGER.debug("执行了main ."); LOGGER.info("记录日志:"); int a=10,b=0; LOGGER.trace("a="+a+" ,b="+b); System.out.println(a/b); }catch (Exception e){ e.printStackTrace(); LOGGER.error("异常:"+e); } }