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

logback日志文件多环境配置路径

项目中遇到问题,springboot项目 本地jar包部署到现场后,经常遇到现场的日志存放的路径会更改,经过查阅,有两种方式,下面简单说明一下。

一、第一种 启动jar包时 添加参数 --logging.config=F:\hgtest\config\logback.xml,采用指定的日志配置文件。

start javaw -jar F:\hgtest\hg.jar --spring.config.location=F:\hgtest\config\ --logging.config=F:\hgtest\config\logback.xml

二、多环境配置日志存放的路径,启动jar会根据spring.profiles.active的值来判断取哪个日志路径保存日志。

1、添加依赖,方便使用<springProperty> 标签。

<!-- Logback Classic Module -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.2.3</version> <!-- 使用适合的版本号 -->
    </dependency>

2、修改logback-spring.xml文件配置

备注:logback.xml 和 logback-spring.xml的区别
logback和logback-spring.xml都可以用来配置logback,但是两者的加载顺序是不一样的。

logback.xml—>application.properties—>logback-spring.xml.
所以 有变量配置在了 application.properties 如果logback.xml进行取值就会取值不到,所以建议在Springboot中 尽量使用 logback-spring.xml。

3、logback-spring.xml修改 增加路径变量读取

 <!-- 日志存放路径 -->
    <springProperty scope="context" name="log.path" source="logging.file.path" defaultValue="./logs" />
   
<!-- 系统日志输出 -->
	<appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
	    <file>${log.path}/sys-info.log</file>
        <!-- 循环政策:基于时间创建日志文件 -->
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
			<fileNamePattern>${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern>
			<!-- 日志最大的历史 15天 -->
			<maxHistory>15</maxHistory>
		</rollingPolicy>
		<encoder>
			<pattern>${log.pattern}</pattern>
		</encoder>
		<filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 过滤的级别 -->
            <level>INFO</level>
            <!-- 匹配时的操作:接收(记录) -->
            <onMatch>ACCEPT</onMatch>
            <!-- 不匹配时的操作:拒绝(不记录) -->
            <onMismatch>DENY</onMismatch>
        </filter>
	</appender>

这里配置了springProperty 用于从 application.properties 中获取文件地址,并且配置了默认地址。

name: logback-spring.xml中可以使用的变量,对应下面引用的变量值。
source:来自 application.properties中配置的变量
defaultValue:获取不到 application.properties中配置的变量时 默认的值,(这里建议直接配置生产环境的位置)

这样配置后,即可把log日志保存到指定的目录下。亲测可用。


http://www.kler.cn/a/466601.html

相关文章:

  • 详解GPT-信息抽取任务 (GPT-3 FAMILY LARGE LANGUAGE MODELS)
  • 前端(API)学习笔记(CLASS 4):进阶
  • 集合划分.
  • windows11安装minikube
  • 【调试记录】在CARLA中插入可以播放视频的组件
  • MySQL(六)MySQL 案例
  • Linux下读取Windows下保存的文件,报错信息中出现“^M“时如何解决?【由于Windows和Linux的换行方式不同造成的-提供两种转换方式】
  • React18路由和Vue3路由进行对比
  • [2024] 如何以 5 种可行的方式在Android中打开 HEIC 文件?
  • aardio —— 虚表 —— 模拟属性框
  • Edge Scdn的应用场景有哪些?
  • VScode SSH 错误:Got bad result from install script 解決
  • CG顶会论文阅读|《科技论文写作》硕士课程报告
  • FreeSWITCH dialplan/default.xml 之释疑
  • 如何删除 Android 设备上的应用程序 | 3种高效方法
  • Springcloud项目-前后端联调(一)
  • 代码随想录算法训练营day21
  • Spring线程池优雅关闭
  • YOLOv8/YOLOv11改进 添加CBAM、GAM、SimAM、EMA、CAA、ECA、CA等多种注意力机制
  • GWAS数据和软件下载
  • JeeSite 快速开发平台:全能企业级快速开发解决方案|GitCode 光引计划征文展示
  • 【深度学习进阶】基于CNN的猫狗图片分类项目
  • pycharm 命令行下的链接,不自动形成链接和定位了。
  • 深入解析-正则表达式
  • github加速源配置
  • RK3588+FPGA全国产异步LED显示屏控制卡/屏幕拼接解决方案