工作纪实53-log4j日志打印文件隔离

在项目中,我有一堆业务日志需要打印,另一部分的日志,是没有格式的,需要被云平台离线解析并收集到kafka或者hdfs、hive等,需要将日志隔离打印到不同的文件

正常的log4j配置是下面这样的,配合@Sl4j直接使用默认的log.info()打印日志,会汇总到web.log中;

如果是其他的logger,则需要:

private Logger dumpLog = LoggerFactory.getLogger("dump_logger");

yml 复制代码
Configuration:
  status: info
  monitorInterval: 30
  properties:
    property:
      name: log.path
      value: /opt/mnt/web/logs
  Appenders:
    RollingFile:
     - name: error_file
       # 清除策略
       DefaultRolloverStrategy:
         # 删除的触发条件
         Delete:
           # 要删除扫描的文件夹
           basePath: ${log.path}
           # 限定扫描的文件名
           IfFileName:
             # 匹配规则 以log结尾的
             glob: "*log"
             # 文件的最新的修改时间间隔
           IfLastModified:
             # 1s 表示1秒前  7d表示7天
             age: 7d
       fileName: ${log.path}/error.log
       filePattern: "${log.path}/error_%d{yyyy-MM-dd}.log"
       PatternLayout:
         Pattern: "[%X{request_id}] %-d{yyyy-MM-dd HH:mm:ss.SSS} - [%p] [%C{1} %M] %m%n"
       Policies:
         TimeBasedTriggeringPolicy:
           interval: 1
           modulate: true
     - name: web_file
       # 清除策略
       DefaultRolloverStrategy:
         # 删除的触发条件
         Delete:
           # 要删除扫描的文件夹
           basePath: ${log.path}
           # 限定扫描的文件名
           IfFileName:
             # 匹配规则 以log结尾的
             glob: "*log"
             # 文件的最新的修改时间间隔
           IfLastModified:
             # 1s 表示1秒前  7d表示7天
             age: 7d
       fileName: ${log.path}/web.log
       filePattern: "${log.path}/web_%d{yyyy-MM-dd}.log"
       PatternLayout:
         Pattern: "[%X{request_id}] %-d{yyyy-MM-dd HH:mm:ss.SSS} - [%p] [%C{1} %M] %m%n"
       Policies:
         TimeBasedTriggeringPolicy:
           interval: 1
           modulate: true
     - name: dump_appender
        # 清除策略
       DefaultRolloverStrategy:
         # 删除的触发条件
         Delete:
           # 要删除扫描的文件夹
           basePath: ${log.path}
           # 限定扫描的文件名
           IfFileName:
             # 匹配规则 以log结尾的
             glob: "*log"
             # 文件的最新的修改时间间隔
           IfLastModified:
             # 1s 表示1秒前  7d表示7天
             age: 7d
       fileName: ${log.path}/dump/dump_log.log
       filePattern: "${log.path}/dump_log%d{yyyy-MM-dd}.log"
       PatternLayout:
         Pattern: "%m%n%ex"
       Policies:
         TimeBasedTriggeringPolicy:
           interval: 1
           modulate: true

    Console:
      name: console
      target: SYSTEM_OUT
      PatternLayout:
        Pattern: "[%X{request_id}] %-d{yyyy-MM-dd HH:mm:ss} - [%p] [%C{1} %M] %m%n"
  Loggers:
    Root:
      level: info
      AppenderRef:
        -  ref: error_file
           level: ERROR
        -  ref: web_file
           level: INFO
        -  ref: console
           level: debug
    Logger:
      - name: dump_logger
        level: info
        AppenderRef:
          - ref: dump_appender
            level: INFO

算法同学希望单独在dump.log中进行日志打印,而后他们去配置采集的逻辑,发现web.log居然也有dump.log的日志,重复打印了;

关键代码:additivity

shell 复制代码
Logger:
  - name: dump_logger
    level: info
    additivity: false
    AppenderRef:
      - ref: dump_appender
        level: INFO

指定了包的日志输出,又指定了这个包下面子包的日志输出,如果在子包的定义标签上加上additivity=false,那么子包中的日志不会打印在父包中,只会在子包中输出

相关推荐
跟着珅聪学java9 分钟前
spring boot +Elment UI 上传文件教程
java·spring boot·后端·ui·elementui·vue
我命由我1234514 分钟前
Spring Boot 自定义日志打印(日志级别、logback-spring.xml 文件、自定义日志打印解读)
java·开发语言·jvm·spring boot·spring·java-ee·logback
lilye6615 分钟前
程序化广告行业(55/89):DMP与DSP对接及数据统计原理剖析
java·服务器·前端
战族狼魂4 小时前
CSGO 皮肤交易平台后端 (Spring Boot) 代码结构与示例
java·spring boot·后端
xyliiiiiL5 小时前
ZGC初步了解
java·jvm·算法
杉之5 小时前
常见前端GET请求以及对应的Spring后端接收接口写法
java·前端·后端·spring·vue
hycccccch6 小时前
Canal+RabbitMQ实现MySQL数据增量同步
java·数据库·后端·rabbitmq
天天向上杰7 小时前
面基JavaEE银行金融业务逻辑层处理金融数据类型BigDecimal
java·bigdecimal
请来次降维打击!!!7 小时前
优选算法系列(5.位运算)
java·前端·c++·算法
用键盘当武器的秋刀鱼7 小时前
springBoot统一响应类型3.5.1版本
java·spring boot·后端