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

logback实践

1:日志区分环境

2:debug info  warn error日志文件不一样

3: 文件滚动日志 

4:启动可带参数  --spring.profiles.active=dev --log.level=info

5:可从配置文件中获取上下文参数

logback-spring.xml  放在 classpath 下面
 

<configuration scan="false" scanPeriod="30 seconds" debug="true"><springProperty scope="context" name="LOG_ROOT" source="log.path" defaultValue="/usr/log"/><springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="default"/><springProperty scope="context" name="LOG_LEVEL" source="log.level" defaultValue="INFO"/><!-- 设置日志格式 --><property name="LOG_PATTERN" value="[%date{ISO8601}] [%-5level] [%thread] [%X{ltid}] [%logger{0}.%M-%L] - %msg%n"/><appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"><target>System.out</target><encoder><pattern>${LOG_PATTERN}</pattern><charset>UTF-8</charset></encoder></appender><appender name="debug" class="ch.qos.logback.core.rolling.RollingFileAppender"><encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"><pattern>${LOG_PATTERN}</pattern><charset>UTF-8</charset></encoder><file>${LOG_ROOT}/${APP_NAME}/debug.log</file><!-- 滚动日志策略: SizeAndTimeBasedRollingPolicy 根据文件大小和时间进行分割归档--><rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"><!-- 指定滚动文件名称的生成规则 --><fileNamePattern>${LOG_ROOT}/${APP_NAME}/debug.%d{yyyy-MM-dd}.%i.log</fileNamePattern><!-- 超过最大磁盘限制后是否删除归档文件 --><cleanHistoryOnStart>true</cleanHistoryOnStart><!-- 单个日志文件大小 --><maxFileSize>20MB</maxFileSize><!--            <maxFileSize>1KB</maxFileSize>--><!-- 归档文件占用磁盘总大小,超过后会根据cleanHistoryOnStart实行,决定是否删除 --><totalSizeCap>1GB</totalSizeCap><!--            <totalSizeCap>10KB</totalSizeCap>--><!-- 保留的历史归档日志文件天数--><maxHistory>30</maxHistory></rollingPolicy><filter class="ch.qos.logback.classic.filter.LevelFilter"><level>DEBUG</level><onMatch>ACCEPT</onMatch><onMismatch>DENY</onMismatch></filter></appender><appender name="info" class="ch.qos.logback.core.rolling.RollingFileAppender"><encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"><pattern>[%date{ISO8601}] [%-5level] [%thread] [%X{ltid}] [%logger-%L] - %msg%n</pattern><charset>UTF-8</charset></encoder><file>${LOG_ROOT}/${APP_NAME}/info.log</file><!-- 滚动日志策略: SizeAndTimeBasedRollingPolicy 根据文件大小和时间进行分割归档--><rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"><!-- 指定滚动文件名称的生成规则 --><fileNamePattern>${LOG_ROOT}/${APP_NAME}/info.%d{yyyy-MM-dd}.%i.log</fileNamePattern><!-- 超过最大磁盘限制后是否删除归档文件 --><cleanHistoryOnStart>true</cleanHistoryOnStart><!-- 单个日志文件大小 --><maxFileSize>20MB</maxFileSize><!--            <maxFileSize>1KB</maxFileSize>--><!-- 归档文件占用磁盘总大小,超过后会根据cleanHistoryOnStart实行,决定是否删除 --><totalSizeCap>1GB</totalSizeCap><!--            <totalSizeCap>10KB</totalSizeCap>--><!-- 保留的历史归档日志文件天数--><maxHistory>30</maxHistory></rollingPolicy><filter class="ch.qos.logback.classic.filter.LevelFilter"><level>INFO</level><onMatch>ACCEPT</onMatch><onMismatch>DENY</onMismatch></filter></appender><appender name="warn" class="ch.qos.logback.core.rolling.RollingFileAppender"><encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"><pattern>[%date{ISO8601}] [%-5level] [%thread] [%X{ltid}] [%logger-%L] - %msg%n</pattern><charset>UTF-8</charset></encoder><file>${LOG_ROOT}/${APP_NAME}/warn.log</file><!-- 滚动日志策略: SizeAndTimeBasedRollingPolicy 根据文件大小和时间进行分割归档--><rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"><!-- 指定滚动文件名称的生成规则 --><fileNamePattern>${LOG_ROOT}/${APP_NAME}/warn.%d{yyyy-MM-dd}.%i.log</fileNamePattern><!-- 超过最大磁盘限制后是否删除归档文件 --><cleanHistoryOnStart>true</cleanHistoryOnStart><!-- 单个日志文件大小 --><maxFileSize>20MB</maxFileSize><!--            <maxFileSize>1KB</maxFileSize>--><!-- 归档文件占用磁盘总大小,超过后会根据cleanHistoryOnStart实行,决定是否删除 --><totalSizeCap>1GB</totalSizeCap><!--            <totalSizeCap>10KB</totalSizeCap>--><!-- 保留的历史归档日志文件天数--><maxHistory>30</maxHistory></rollingPolicy><filter class="ch.qos.logback.classic.filter.LevelFilter"><level>WARN</level><onMatch>ACCEPT</onMatch><onMismatch>DENY</onMismatch></filter></appender><appender name="error" class="ch.qos.logback.core.rolling.RollingFileAppender"><encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"><pattern>${LOG_PATTERN}</pattern><charset>UTF-8</charset></encoder><file>${LOG_ROOT}/${APP_NAME}/error.log</file><!-- 滚动日志策略: SizeAndTimeBasedRollingPolicy 根据文件大小和时间进行分割归档--><rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"><!-- 指定滚动文件名称的生成规则 --><fileNamePattern>${LOG_ROOT}/${APP_NAME}/error.%d{yyyy-MM-dd}.%i.log</fileNamePattern><!-- 超过最大磁盘限制后是否删除归档文件 --><cleanHistoryOnStart>true</cleanHistoryOnStart><!-- 单个日志文件大小 --><maxFileSize>20MB</maxFileSize><!--            <maxFileSize>1KB</maxFileSize>--><!-- 归档文件占用磁盘总大小,超过后会根据cleanHistoryOnStart实行,决定是否删除 --><totalSizeCap>1GB</totalSizeCap><!--            <totalSizeCap>10KB</totalSizeCap>--><!-- 保留的历史归档日志文件天数--><maxHistory>30</maxHistory></rollingPolicy><filter class="ch.qos.logback.classic.filter.ThresholdFilter"><level>ERROR</level></filter></appender><!-- 级别依次为【从高到低】:FATAL > ERROR > WARN > INFO > DEBUG > TRACE  --><springProfile name="txtest,txprod,prod,test"><root level="${LOG_LEVEL}"><!--日志输出到文件--><appender-ref ref="debug"/><appender-ref ref="info"/><appender-ref ref="warn"/><appender-ref ref="error"/></root></springProfile><!-- 本地、开发环境,日志配置 可以写logback支持的所有节点 --><springProfile name="local,dev"><root level="${LOG_LEVEL}"><!--控制台日志:生产环境建议关掉--><appender-ref ref="STDOUT"/><appender-ref ref="debug"/><appender-ref ref="info"/><appender-ref ref="warn"/><appender-ref ref="error"/></root><!--    一般dao操作被项目封装可以设置项目上的封装路径--><logger name="com.ikeeper.mapper.base" level="debug"/></springProfile><!--打印SQL--><!--    <logger name="java.sql.Connection" level="DEBUG"/>--><!--    <logger name="java.sql.Statement" level="DEBUG"/>--><!--    <logger name="java.sql.PreparedStatement" level="DEBUG"/>--><!--    一般dao操作被项目封装可以设置项目上的封装路径--><!--    <logger name="com.ikeeper.mapper.base" level="debug"/>--></configuration>

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

相关文章:

  • 深入理解java虚拟机---自动内存管理
  • 粉笔规范词积累(文化发展)
  • 如何在Ubuntu部署Emlog,并将本地博客发布至公网可远程访问
  • Axios
  • 数据仓库选型建议
  • 每日一题——LeetCode1470.重新排列数组
  • 网络安全--网鼎杯2018漏洞复现(二次注入)
  • CSS篇--transform
  • 阿里云国际-在阿里云服务器上快速搭建幻兽帕鲁多人服务器
  • vite 快速搭建 Vue3.0项目
  • 深入理解Python爬虫的Response对象
  • centos7下docker的安装
  • Excel SUMPRODUCT函数用法(乘积求和,分组排序)
  • C#上位机与三菱PLC的通信08---开发自己的通讯库(A-1E版)
  • ABAQUS应用04——集中质量的添加方法
  • [嵌入式系统-24]:RT-Thread -11- 内核组件编程接口 - 网络组件 - TCP/UDP Socket编程
  • 【ansible】认识ansible,了解常用的模块
  • 【LeetCode】升级打怪之路 Day 01:二分法
  • 单片机stm32智能鱼缸
  • 面试经典150题——生命游戏
  • 【C++】C++11下线程库
  • 面试经典150题——矩阵置零
  • 多端开发围炉夜话
  • 分治算法总结(Java)
  • 【云原生系列之kubernetes】--Ingress使用
  • 练习:鼠标类设计之2_类和接口
  • 【程序员英语】【美语从头学】初级篇(入门)(笔记)Lesson 15 At the Department Store 在百货商店
  • linux 安装、删除 JTAG驱动
  • CSS的伪类选择器:nth-child()
  • python celery使用队列