文档章节

日志文件分离配置

trayvon
 trayvon
发布于 2017/06/01 21:57
字数 1134
阅读 52
收藏 0

简介

在实际的应用中有很多需要分离日志的需求,比如为了方便监控错误日志就会把错误日志分开,有一些重要的接口需要单独做日志的也需要单独分开。logback和log4j2都能通过配置简单实现日志的分离。log4j2和logback的配置是差不多的,这里就以logback为例介绍一下如何分离日志文件。

有2个重要的抽象一个是Appender,另一个是Logger,Logger是对日志的抽象作用是输出日志,至于怎么输出有实现决定,Appender是对日志输出的位置的抽象,在logback中日志过滤器也被封装到了Appender中。过滤器被添加到Appender中,添加一个或多个过滤器后,可以用任意条件对日志进行过滤。Appender有多个过滤器时,按照配置顺序执行。当然要分离日志,还要了解下面几个概念。

FilterReply:

过滤器的响应方式,过滤器在执行一个过滤的时候会利用FilterReply枚举,这个枚举包含3个值,分别是DENY,NEUTRAL,ACCEPT。 DENY:日志将立即被抛弃不再经过其他过滤器 NEUTRAL:有序列表里的下个过滤器过接着处理日志 ACCEPT:日志会被立即处理,不再经过剩余过滤器。

LevelFilter

级别过滤器,根据日志级别进行过滤。如果日志级别等于配置级别,过滤器会根据onMatch 和 onMismatch接收或拒绝日志。有以下子节点:

<level>:设置过滤级别

<onMatch>:FilterReply枚举值,用于配置匹配level时的操作

<onMismatch>:FilterReply枚举值,用于配置不匹配level时的操作

ThresholdFilter

临界值过滤器,过滤掉低于指定临界值的日志。当日志级别等于或高于临界值时,过滤器返回NEUTRAL;当日志级别低于临界值时,日志会被拒绝。 ThresholdFilter和LevelFilter差不多LevelFilter是对指定级别的进行过滤,只是针对一个级别的,而ThresholdFilter是一个阀值,针对多个级别的。可以通过多个LevelFilter来实现ThresholdFilter同样的功能。

实例

下面通过一个简单的实例来展示一下日志分离。

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class LogStart {
    
    private static final Logger logger = LoggerFactory.getLogger(LogStart.class);
    
    public static void main(String[] args) {
        logger.debug("debug log");
        logger.info("info log");
        logger.warn("warn log");
        logger.error("error log");
        ImportantLog.log();
    }

}
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class ImportantLog {
    
    private static final Logger logger = LoggerFactory.getLogger(ImportantLog.class);
    
    public static void log(){
        logger.debug("debug log");
        logger.info("info log");
        logger.warn("warn log");
        logger.error("error log");
    }

}
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">

    <property name="LOG_DIR" value="E:/logs" />

    <!-- 控制台日志 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <Pattern>[%d{yyyy-MM-dd HH:mm:ss}] [%5level] %logger{36}[%file:%line]- %msg%n</Pattern>
        </encoder>
    </appender>

    <appender name="FILE"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_DIR}/base-%d{yyyy-MM-dd}.log
            </fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <encoder>
            <Pattern>[%d{yyyy-MM-dd HH:mm:ss}] [%5level] %logger{36}[%file:%line] - %msg%n</Pattern>
        </encoder>
    </appender>

    <appender name="ERROR_WARN_FILE"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>warn</level>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_DIR}/error-warn-%d{yyyy-MM-dd}.log
            </fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <encoder>
            <Pattern>[%d{yyyy-MM-dd HH:mm:ss}] [%5level] %logger{36}[%file:%line] - %msg%n</Pattern>
        </encoder>
    </appender>

    <appender name="INFO_FILE"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_DIR}/info-%d{yyyy-MM-dd}.log
            </fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <encoder>
            <Pattern>[%d{yyyy-MM-dd HH:mm:ss}] [%5level] %logger{36}[%file:%line] - %msg%n</Pattern>
        </encoder>
    </appender>

    <appender name="IMPORTANT_LOG_FILE"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_DIR}/important-%d{yyyy-MM-dd}.log
            </fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <encoder>
            <Pattern>[%d{yyyy-MM-dd HH:mm:ss}] [%5level] %logger{36}[%file:%line] - %msg%n</Pattern>
        </encoder>
    </appender>

    <logger name="org.springframework" level="ERROR"></logger>

    <!-- name:包或者类名 additivity:是否向上级传递打印信息,默认false cn.freemethod.log.ImportantLog:类的全路径 
        可以单独设置一个appender来输出超时的日志 -->
    <logger name="cn.freemethod.log.ImportantLog" level="INFO"
        additivity="false">
        <appender-ref ref="IMPORTANT_LOG_FILE" />
    </logger>

    <root level="DEBUG">
        <!-- <appender-ref ref="FILE" /> -->
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="ERROR_WARN_FILE" />
        <appender-ref ref="INFO_FILE" />
    </root>

</configuration>

上面的配置文件配置了4个Appender,其中CONSOLE输出到控制台的。ERROR_WARN_FILE配置了一个ThresholdFilter只输出warn和error级别的日志。INFO_FILE配置了一个LevelFilter只输出info日志。IMPORTANT_LOG_FILE是为了重要接口单独配置输出文件位置的Appender。提供给name为cn.freemethod.log.ImportantLog的Logger使用。这个Logger的additivity="false"表示这个Logger输出后就不向父级输出了。Logger默认的父级是root,也就是表示如果配置了additivity="false"就不会向root下的Appender输出了。可以把additivity="false"改为additivity="true"试一试效果。

分离日志

© 著作权归作者所有

共有 人打赏支持
trayvon
粉丝 15
博文 124
码字总数 184644
作品 1
程序员
Nginx系列-4.Nginx日志配置及日志切割

Nginx系列-4.Nginx日志配置及日志切割 目录 - Nginx系列 Nginx系列-1.Linux下安装Nginx Nginx系列-2.配置LNMP(Linux、Nginx、MySQL、PHP)架构 Nginx系列-3.配置Nginx虚拟主机 Nginx系列-4....

ngle
06/08
0
0
mysql的复制集群,及读写分离

为什么要设置mysql集群? 为了减轻,mysql服务器的IO压力,设置多个其他mysql服务器帮他分担读写操作 1.mysql复制集群的类型 主从架构(从服务器只读,不可写) 一主一从, 一主多重 主主架构...

一期一会cc
08/08
0
0
Nginx系列-9.配置NFS实现Nginx实现动静分离

Nginx系列-9.配置NFS实现Nginx实现动静分离 目录 - Nginx系列 Nginx系列-1.Linux下安装Nginx Nginx系列-2.配置LNMP(Linux、Nginx、MySQL、PHP)架构 Nginx系列-3.配置Nginx虚拟主机 Nginx系...

ngle
06/10
0
0
Nginx系列-8.配置Nginx+Apache实现动静分离

Nginx系列-8.配置Nginx+Apache实现动静分离 目录 - Nginx系列 Nginx系列-1.Linux下安装Nginx Nginx系列-2.配置LNMP(Linux、Nginx、MySQL、PHP)架构 Nginx系列-3.配置Nginx虚拟主机 Nginx系...

ngle
06/10
0
0
mongodb写安全的相关配置

客户端: WriteConcern JOURNALSAFE 日志安全模式,每一次写操作需要等待日志被同步刷新(fsyncdata, msync)到磁盘上,server才会返回给客户端成功写入的响应。 服务端:journalCommitInte...

智深
2013/07/30
0
0

没有更多内容

加载失败,请刷新页面

加载更多

awk命令用法介绍

10月18日任务 9.6/9.7 awk 1.awk(上)(下) 1.awk 分段操作功能 指定分隔符,并把第一段打印出来,不会改动文件内容 将所有内容打印出来 awk 没有指定分隔符号,则会默认用空格或者空白字符...

hhpuppy
53分钟前
3
0
Spring Cloud Eureka Server高可用之:在线扩容

本文共 1591字,阅读大约需要 6分钟 ! 概述 业务微服务化以后,我们要求服务高可用,于是我们可以部署多个相同的服务实例,并引入负载均衡机制。而微服务注册中心作为微服务化系统的重要单元...

CodeSheep
今天
2
0
内网esxi主机上安装CoreOS虚拟机

CoreOS是一个为专门运行容器而设计的轻量级linux发行版,旨在通过轻量的系统架构和灵活的应用程序部署能力简化数据中心的维护成本和复杂度。它没有包管理工具,运行容器化应用以提供服务;默...

hiwill
今天
1
0
20181018 上课截图

![](https://oscimg.oschina.net/oscnet/49f66c08ab8c59a21a3b98889d961672f30.jpg) ![](https://oscimg.oschina.net/oscnet/a61bc2d618b403650dbd4bf68a671fabecb.jpg)......

小丑鱼00
今天
3
0
WinDbg

参考来自:http://www.cnit.net.cn/?id=225 SRV*C:\Symbols*http://msdl.microsoft.com/download/symbols ctrl + d to open dump_file Microsoft (R) Windows Debugger Version 6.12.0002.633......

xueyuse0012
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部