news 2026/4/15 13:50:56

Java项目日志持久化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java项目日志持久化

前言

  • 当我们在服务器上运行Java的时候,发布新功能或者重启容器的时候,对于已有的日志会直接丢失,这很不方便我们排查以往的bug。所以我们需要把日志收集起来,方便我们查看以往的日志情况。

正文

  • 首先,在 resources 文件夹下添加 logback-spring.xml 文件,内容如下,这是最基本的,可以自己添加内容(如彩色日志等,这里就不做演示了,只演示最基本的。)我本地激活的是text环境,所以我把test的位置放在了当前目录下,各位可以按照自己的情况修改value的值即可
<?xml version="1.0" encoding="UTF-8"?><configuration><!-- 开发环境:使用用户主目录下的 logs 文件夹 --><springProfilename="dev"><propertyname="LOG_PATH"value="${user.home}/logs/travel-echo"/></springProfile><!-- 生产环境:容器内标准路径 --><springProfilename="prod"><propertyname="LOG_PATH"value="/app/logs"/></springProfile><!-- 测试环境:容器内标准路径 --><springProfilename="test"><propertyname="LOG_PATH"value="./logs"/></springProfile><!-- 文件输出 --><appendername="FILE"class="ch.qos.logback.core.rolling.RollingFileAppender"><file>${LOG_PATH}/app.log</file><rollingPolicyclass="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><!-- 按天滚动,保留180天 --><fileNamePattern>${LOG_PATH}/app.%d{yyyy-MM-dd}.log</fileNamePattern><maxHistory>180</maxHistory><totalSizeCap>10GB</totalSizeCap></rollingPolicy><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><!-- 控制台输出(用于 docker logs) --><appendername="CONSOLE"class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><rootlevel="INFO"><appender-refref="FILE"/><appender-refref="CONSOLE"/><!-- 👈 同时输出到文件和控制台 --></root></configuration>
  • 如果是只有本地运行或者直接使用jar包运行进行收集日志,配置 logback-spring.xml 就已经可以了,洛阳是使用docker-compose进行启动的服务,所以还要配置一下 docker-compose.yml 进行一下映射,把docker容器内的文件路径挂载到宿主机上边,不然重启容器,所有收集的日志也就没了。(怎么使用docker-compose启动Java服务,请看这里:使用docker运行Java项目)
version:'3.8'services:te:build:.image:tecontainer_name:teenvironment:# 启用远程调试(开发时临时加)-JAVA_TOOL_OPTIONS=-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=*:8082-JAVA_OPTS=-Xms64m-Xmx192m-XX:MetaspaceSize=48m-XX:MaxMetaspaceSize=96m-XX:+UseG1GC-Djava.security.egd=file:/dev/./urandom-XX:+TieredCompilation-XX:TieredStopAtLevel=1-XX:CICompilerCount=2mem_limit:350mmem_reservation:200mvolumes:-./log:/app/logs# 👈 宿主机路径:容器内路径,日志收集到宿主机里边进行持久化ports:-"8081:8081"-"8082:8082"restart:unless-stopped

结尾

  • 朝花 夕拾
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 18:19:32

QMQTT完全实战指南:Qt框架下的MQTT客户端开发全解析

QMQTT完全实战指南&#xff1a;Qt框架下的MQTT客户端开发全解析 【免费下载链接】qmqtt MQTT client for Qt 项目地址: https://gitcode.com/gh_mirrors/qm/qmqtt QMQTT作为专为Qt 5设计的MQTT客户端库&#xff0c;为物联网通信和实时数据传输提供了稳定可靠的解决方案。…

作者头像 李华
网站建设 2026/4/13 15:18:09

【JavaWeb】HttpServletRequest_获得请求中的键值对参数相关API

目录获得请求中的键值对参数相关API根据参数名获取参数值获取所有的参数名返回所有参数的map集合获得请求体中的非键值对数据获取请求的servlet映射路径获得请求中的键值对参数相关API 在web下新建index.html 根据参数名获取参数值 编写servlet5 提交表单 获取所有的参数名 返…

作者头像 李华
网站建设 2026/4/9 0:28:41

DDR5开启XMPEXPO后不稳定怎么办

嘿&#xff0c;各位装机小伙伴&#xff01;是不是刚给自己的爱机换上了全新的DDR5内存&#xff0c;兴冲冲地跑进BIOS里打开XMP或EXPO&#xff0c;准备享受一飞冲天的快感&#xff0c;结果……电脑却跟你开起了玩笑&#xff1f;蓝屏、死机、游戏闪退&#xff0c;甚至干脆开不了机…

作者头像 李华
网站建设 2026/4/11 23:33:03

阻抗影响因素深度剖析:从线宽到材质的全面掌控

作为PCB技术运营专家&#xff0c;我经常被问到&#xff1a;“为什么我按照公式计算出的阻抗与实际测量值有差异&#xff1f;”今天&#xff0c;我们就来深入探讨影响PCB走线阻抗的各种因素&#xff0c;帮助你在设计中实现更精确的控制。​线路几何参数&#xff1a;阻抗设计的“…

作者头像 李华
网站建设 2026/4/8 21:31:58

GalTransl:零基础也能轻松完成的Galgame汉化工具

还在为日文Galgame无法理解剧情而烦恼吗&#xff1f;GalTransl作为一款创新的AI翻译工具&#xff0c;专门为Galgame汉化而生&#xff0c;让每个人都能轻松享受汉化乐趣。这款基于大语言模型的自动化翻译解决方案&#xff0c;彻底改变了传统Galgame汉化的复杂流程。 【免费下载链…

作者头像 李华