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

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

结尾

  • 朝花 夕拾
http://www.cnnetsun.cn/news/61388.html

相关文章:

  • 仿生记忆革命:字节跳动AHN技术突破大模型长文本处理瓶颈
  • 云服务器新手必看:常见名词和知识整理,一文搞懂
  • Xiaomi Home Integration代码质量优化终极指南:从根源解决智能家居设备控制瓶颈
  • 雷电预警监测系统:储油罐雷电监测预警系统​
  • 冰点还原安装破解
  • 腾讯混元Hunyuan-A13B:智能体技术突破与800亿参数MoE架构的完美融合
  • 重新定义B站体验:从功能界面到个性空间的华丽转变
  • 【每天学习一点算法 2025/12/15】环形链表
  • DDR5和DDR4比有什么区别,值得升级吗?
  • 海尔智能设备HomeAssistant接入完整教程
  • 大学生,不狠下心来学习,就等着被卷出局!
  • 350M参数颠覆行业:Liquid AI轻量翻译模型重塑日英互译格局
  • 幼儿园组织结构图绘制 保教团队分工可视化
  • 40、vi 和 Vim 编辑器命令全解析
  • 42、Vile 9.6 选项设置与常见问题解决指南
  • UniHacker终极指南:免费解锁Unity完整开发环境的简单方法
  • 软考-系统集成项目管理工程师案例简答题
  • 如何快速掌握TradingVue.js:专业交易图表库的完整指南 [特殊字符]
  • 4.2 技术文档自动生成:从代码到专业文档的转化
  • FMEA在软件可靠性测试中的实践与应用
  • Playwright MCP在UI自动化测试中的定位与思考
  • 友达 G170ETN02.1 工业液晶显示屏:17.0 英寸超宽温高亮度场景的显示驱动技术解析
  • Harmony之路:服务卡片——打造桌面上的“原子化服务“
  • JVM内存模型详解
  • 源启高校・郑航站圆满落幕!鸿蒙 6.0 适配实战 + 职业机遇双赋能,解锁开源新可能
  • 腾讯混元大模型开源:520亿激活参数改写行业效率标准
  • 计算机专业毕业=码农?网络安全正在重塑你的职业天花板
  • 120亿参数颠覆智能体市场:GLM-4.5-Air-FP8如何重新定义企业AI效率标准
  • Forget-Me-Not: 建议采用一种简单的提示技术,防止在长时间的提示中遗忘信息
  • 数据处理服务:G1/ZGC如何提升稳定性