当前位置: 首页 > news >正文

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

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

正常的log4j配置是下面这样的,配合@Sl4j直接使用默认的log.info()打印日志,会汇总到web.log中;
如果是其他的logger,则需要:
private Logger dumpLog = LoggerFactory.getLogger(“dump_logger”);

Configuration:status: infomonitorInterval: 30properties:property:name: log.pathvalue: /opt/mnt/web/logsAppenders:RollingFile:- name: error_file# 清除策略DefaultRolloverStrategy:# 删除的触发条件Delete:# 要删除扫描的文件夹basePath: ${log.path}# 限定扫描的文件名IfFileName:# 匹配规则 以log结尾的glob: "*log"# 文件的最新的修改时间间隔IfLastModified:# 1s 表示1秒前  7d表示7天age: 7dfileName: ${log.path}/error.logfilePattern: "${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: 1modulate: true- name: web_file# 清除策略DefaultRolloverStrategy:# 删除的触发条件Delete:# 要删除扫描的文件夹basePath: ${log.path}# 限定扫描的文件名IfFileName:# 匹配规则 以log结尾的glob: "*log"# 文件的最新的修改时间间隔IfLastModified:# 1s 表示1秒前  7d表示7天age: 7dfileName: ${log.path}/web.logfilePattern: "${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: 1modulate: true- name: dump_appender# 清除策略DefaultRolloverStrategy:# 删除的触发条件Delete:# 要删除扫描的文件夹basePath: ${log.path}# 限定扫描的文件名IfFileName:# 匹配规则 以log结尾的glob: "*log"# 文件的最新的修改时间间隔IfLastModified:# 1s 表示1秒前  7d表示7天age: 7dfileName: ${log.path}/dump/dump_log.logfilePattern: "${log.path}/dump_log%d{yyyy-MM-dd}.log"PatternLayout:Pattern: "%m%n%ex"Policies:TimeBasedTriggeringPolicy:interval: 1modulate: trueConsole:name: consoletarget: SYSTEM_OUTPatternLayout:Pattern: "[%X{request_id}] %-d{yyyy-MM-dd HH:mm:ss} - [%p] [%C{1} %M] %m%n"Loggers:Root:level: infoAppenderRef:-  ref: error_filelevel: ERROR-  ref: web_filelevel: INFO-  ref: consolelevel: debugLogger:- name: dump_loggerlevel: infoAppenderRef:- ref: dump_appenderlevel: INFO

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

关键代码:additivity

Logger:- name: dump_loggerlevel: infoadditivity: falseAppenderRef:- ref: dump_appenderlevel: INFO

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

http://www.lryc.cn/news/404626.html

相关文章:

  • 7月21日,贪心练习
  • FPGA DNA 获取 DNA_PORT
  • 使用 hutool工具实现导入导出功能。
  • 大语言模型-Transformer-Attention Is All You Need
  • spring(二)
  • MAC 数据恢复软件: STELLAR Data Recovery For MAC V. 12.1 更多增强功能
  • 初识godot游戏引擎并安装
  • Windows配置Qt+VLC
  • 本地部署 mistralai/Mistral-Nemo-Instruct-2407
  • 2月科研——arcgis计算植被差异
  • 深入理解Android中的缓存与文件存储目录
  • Linux_生产消费者模型
  • 【Vue】`v-if` 指令详解:条件渲染的高效实现
  • junit mockito Base基类
  • 朋友圈运营分享干货2
  • linux中创建一个名为“thread1“,堆栈大小为1024,优先级为2的线程
  • 架构以及架构中的组件
  • Docker启动PostgreSql并设置时间与主机同步
  • 提升无线网络安全:用Python脚本发现并修复WiFi安全问题
  • #三元运算符(python/java/c)
  • 探索Python自然语言处理的新篇章:jionlp库介绍
  • Deepin系统,中盛科技温湿度模块读温度纯c程序(备份)
  • 文件包含漏洞: 函数,实例[pikachu_file_inclusion_local]
  • 学习计划2024下半年
  • RabbitMQ的学习和模拟实现|sqlite轻量级数据库的介绍和简单使用
  • AI批量剪辑,批量发布大模型矩阵系统搭建开发
  • SpringMVC源码深度解析(中)
  • Mojo模型动态批处理:智能预测的终极武器
  • 人、智能、机器人……
  • SpringCloud------Sentinel(微服务保护)