热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

logback.xml动态配置程序路径的操作

这篇文章主要介绍了logback.xml动态配置程序路径的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

1.普通java程序

如下配置的logback.xml

<&#63;xml version="1.0" encoding="UTF-8"&#63;>

 
  
  
  
  
  
 
  
    
      ${LOG_PATTERN}
      ${LOG_CHARSET}
    
  
 
  
    ${LOGS_HOME}/${SUB_LOG_HOME}/logback-demo.log
    
      ${LOG_PATTERN}
      ${LOG_CHARSET}
    
    
      ${LOGS_HOME}/${SUB_LOG_HOME}/logback-demo-%d{yyyy-MM-dd}.log
      30
    
  
 
  
    ${LOGS_HOME}/${SUB_LOG_HOME}/logback-demo.error.log
    
      ${LOGS_HOME}/${SUB_LOG_HOME}/logback-demo-%d{yyyy-MM-dd}.error.log
      20
    
    
      ${LOG_PATTERN}
      true
    
    
      ERROR
      ACCEPT
      DENY
    
  
 
  
    
    
    
  
 

property标签由name和value组成,上边定义的name可以在下边通过${name}引用。

value的值可以直接在xml中写死,也可以通过程序启动时候通过jvm虚拟机参数配置来传入,比如此处是-DSUB_LOG_HOME=xxx。

idea中配置:

2.spring boot应用

spring boot应用中将logback-spring.xml放置在resources目录,内容如下:

<&#63;xml version="1.0" encoding="UTF-8"&#63;>

 
  
  
 
  
  
  
  
 
  
  
  
  
  
  
 
  
    
      ${CONSOLE_LOG_PATTERN}
    
  
  
    ${LOG_HOME}/${SUB_LOG_HOME}/${LOG_NAME}.log
    
      ${LOG_HOME}/${SUB_LOG_HOME}/${LOG_NAME}.log-%d{yyyy-MM-dd}.%i.zip
      20
      100MB
    
    
      ${FILE_LOG_PATTERN}
      true
    
  
  
    ${LOG_HOME}/${SUB_LOG_HOME}/${LOG_NAME}.error.log
    
      ${LOG_HOME}/${SUB_LOG_HOME}/${LOG_NAME}.error.log-%d{yyyy-MM-dd}.%i.zip
      20
      100MB
    
    
      ${FILE_LOG_PATTERN}
      true
    
    
      ERROR
      ACCEPT
      DENY
    
  
 
  
    ${LOG_HOME}/${SUB_LOG_HOME}/import/${LOG_NAME}.log
    
      ${FILE_LOG_PATTERN}
      true
    
    
      ${LOG_HOME}/${SUB_LOG_HOME}/import/${LOG_NAME}-%d{yyyy-MM-dd}.log
      7
    
  
 
  
    
  
 
  
  
 
  
    
    
    
  

该配置文件中除了使用还使用了其中source为引用的spring配置中的变量,比如此处是logback.logPath和logback.subLogPath这两个值的传入可以通过spring boot配置文件传入,也可以通过程序启动时候动态传入,比如--logback.subLogPath=xxx

补充:logback.xml 自动读取日志存储路径

文件的命名和加载顺序有关logback.xml早于application.yml加载,logback-spring.xml晚于application.yml加载

如果logback配置需要使用application.yml中的属性,需要命名为logback-spring.xml

logback使用application.yml中的属性

使用springProperty才可使用application.yml中的值 可以设置默认值

<&#63;xml version="1.0" encoding="UTF-8"&#63;>

  
  
  
  

  
  
  
  
  
    
      ${log.pattern}
    
  
  
  
    ${log.path}/sys-info.log
    
    
      
      ${log.path}/sys-info.%d{yyyy-MM-dd}.log
      
      60
    
    
      ${log.pattern}
    
    
      
      INFO
      
      ACCEPT
      
      DENY
    
  
  
    ${log.path}/sys-error.log
    
    
      
      ${log.path}/sys-error.%d{yyyy-MM-dd}.log
      
      60
    
    
      ${log.pattern}
    
    
      
      ERROR
      
      ACCEPT
      
      DENY
    
  
  
  
    ${log.path}/sys-user.log
    
      
      ${log.path}/sys-user.%d{yyyy-MM-dd}.log
      
      60
    
    
      ${log.pattern}
    
  
  
  
  
  
  
    
  
  
  
    
    
  
  
  
    
  

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。


推荐阅读
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • Sleuth+zipkin链路追踪SpringCloud微服务的解决方案
    在庞大的微服务群中,随着业务扩展,微服务个数增多,系统调用链路复杂化。Sleuth+zipkin是解决SpringCloud微服务定位和追踪的方案。通过TraceId将不同服务调用的日志串联起来,实现请求链路跟踪。通过Feign调用和Request传递TraceId,将整个调用链路的服务日志归组合并,提供定位和追踪的功能。 ... [详细]
  • 本文总结了初学者在使用dubbo设计架构过程中遇到的问题,并提供了相应的解决方法。问题包括传输字节流限制、分布式事务、序列化、多点部署、zk端口冲突、服务失败请求3次机制以及启动时检查。通过解决这些问题,初学者能够更好地理解和应用dubbo设计架构。 ... [详细]
  • 项目运行环境配置及可行性分析
    本文介绍了项目运行环境配置的要求,包括Jdk1.8、Tomcat7.0、Mysql、HBuilderX等工具的使用。同时对项目的技术可行性、操作可行性、经济可行性、时间可行性和法律可行性进行了分析。通过对数据库的设计和功能模块的设计,确保系统的完整性和安全性。在系统登录、系统功能模块、管理员功能模块等方面进行了详细的介绍和展示。最后提供了JAVA毕设帮助、指导、源码分享和调试部署的服务。 ... [详细]
  • 开发笔记:读《分布式一致性原理》JAVA客户端API操作2
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了读《分布式一致性原理》JAVA客户端API操作2相关的知识,希望对你有一定的参考价值。创 ... [详细]
  • Kylin 单节点安装
    软件环境Hadoop:2.7,3.1(sincev2.5)Hive:0.13-1.2.1HBase:1.1,2.0(sincev2.5)Spark(optional)2.3.0K ... [详细]
  • 我们在之前的文章中已经初步介绍了Cloudera。hadoop基础----hadoop实战(零)-----hadoop的平台版本选择从版本选择这篇文章中我们了解到除了hadoop官方版本外很多 ... [详细]
  • 我正在使用sql-serverkafka-connect和debezium监视sqlserver数据库,但是当我发布并运行我的wo ... [详细]
  • python zookeeeper 学习和操作
    1.zookeeeper介绍ZooKeeper是一个为分布式应用所设计的分布的、开源的协调服务,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,简化分布式应用协调及其管理的 ... [详细]
author-avatar
书友70518356
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有