文档章节

日志文件分离配置

trayvon
 trayvon
发布于 2017/06/01 21:57
字数 1134
阅读 61
收藏 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"试一试效果。

分离日志

© 著作权归作者所有

共有 人打赏支持
上一篇: Zookeeper ACL
trayvon
粉丝 14
博文 125
码字总数 185343
作品 1
程序员
私信 提问
mysql的复制集群,及读写分离

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

一期一会cc
08/08
0
0
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
mongodb写安全的相关配置

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

智深
2013/07/30
0
0
LNMP架构php-fpm相关配置

11月30日任务 12.21 php-fpm的pool 12.22 php-fpm慢执行日志 12.23 open_basedir 12.24 php-fpm进程管理 php-fpm的pool php-fpm.conf可以设置多个pool,在其中一个pool资源耗尽,会导致其他站...

robertt15
12/02
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

没有更多内容

加载失败,请刷新页面

加载更多

怎样实际项目中运用责任链模式

1 模式概要 1.1 简介 责任链模式为请求创建一个接收者对象链,每个接收者都包含对另一个接收者的引用,如果一个对象不能处理该请求,那么它会把请求传给下一个接收者,依此类推 责任链模式避...

小刀爱编程
3分钟前
1
0
【宇润日常疯测-004】JS 遍历数组如何快!快!快!

首先,我就是一后端全栈,对前端也只是会用罢了。闲的无聊来测测,不深究,只看表面,不喜勿喷! 遍历数组在写 JS 代码时候一定是经常用的,那么怎么遍历能达到最高效率呢,很多人一定没有测...

宇润
7分钟前
4
1
Linux系统如何定制History输出格式

Linux系统使用History命令来查看系统的运行记录,从而找出一些问题。但是History输出的数据中常常没有时间等信息。本文就来教大家Linux系统如何定制History输出格式。   具体方法如下 以r...

linuxprobe16
9分钟前
1
0
(一) pyhon 基础语法(数值 字符串 元组 列表 字典)

1、python的数据类型: 数值 字符串 列表 元组 字典; 数值类型包括; 整型(int) 长整型(long) 浮点型(float) 复数型 字符串; 可以通过type() 来查看是什么类型的; 注释:len()只支持 字符...

芬野de博客
9分钟前
1
0
Android闹钟 AlarmManager的使用

Android闹钟 AlarmManager的使用 AlarmManager介绍   AlarmManager这个类提供对系统闹钟服务的访问接口。   你可以为你的应用设定一个在未来某个时间唤醒的功能。   当闹钟响起,实际上...

东街小霸王
10分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部