Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决

问题一:如何配置Logback以仅记录错误级别的日志到一个滚动文件中?

如何配置Logback以仅记录错误级别的日志到一个滚动文件中?


参考回答:

为了仅记录错误级别的日志到一个滚动文件中,你可以在Logback配置文件中定义一个RollingFileAppender,并为其添加一个LevelFilter。这个过滤器会检查日志事件的级别,只接受错误(ERROR)级别的日志。配置示例如下:

<appender name="TOMS-ERROR-APPENDER" 
class="ch.qos.logback.core.rolling.RollingFileAppender"> 
<File>${LOG_PATH}/toms-error.log</File> 
<filter class="ch.qos.logback.classic.filter.LevelFilter"> 
<level>ERROR</level> 
<onMatch>ACCEPT</onMatch> 
<onMismatch>DENY</onMismatch> 
</filter> 
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> 
<FileNamePattern>${LOG_PATH}/logs_saved/toms-error.%d{yyyy-MM-dd}.%i.log</FileNamePattern> 
<maxHistory>5</maxHistory> 
<maxFileSize>2GB</maxFileSize> 
<totalSizeCap>10GB</totalSizeCap> 
</rollingPolicy> 
<encoder> 
<pattern><![CDATA[%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%level] [traceId:%X{EAGLEEYE_TRACE_ID}] [%class:%line] - %m %n ]]></pattern> 
<charset>UTF-8</charset> 
</encoder> 
</appender>


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/674541


问题二:如何为异常日志配置一个基于时间的滚动文件追加器,并设置其滚动策略和文件命名模式?

如何为异常日志配置一个基于时间的滚动文件追加器,并设置其滚动策略和文件命名模式?


参考回答:

要为异常日志配置一个基于时间的滚动文件追加器,你可以在Logback配置文件中定义一个RollingFileAppender,并使用TimeBasedRollingPolicy作为其滚动策略。你可以通过<FileNamePattern>来设置滚动后的文件命名模式。配置示例如下:

<appender name="TOMS-EXCEPTION-APPENDER" 
class="ch.qos.logback.core.rolling.RollingFileAppender"> 
<File>${LOG_PATH}/toms-exception.log</File> 
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> 
<FileNamePattern>${LOG_PATH}/logs_saved/toms-exception.%d{yyyy-MM-dd}.log</FileNamePattern> 
<maxHistory>5</maxHistory> 
</rollingPolicy> 
<encoder> 
<pattern><![CDATA[%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%level] [traceId:%X{EAGLEEYE_TRACE_ID}] [%class:%line] - %m %n ]]></pattern> 
<charset>UTF-8</charset> 
</encoder> 
</appender>

这个配置将异常日志输出到${LOG_PATH}/toms-exception.log,并根据时间(每天)进行滚动。滚动后的日志文件将按照${LOG_PATH}/logs_saved/toms-exception.%d{yyyy-MM-dd}.log的模式命名,并且只保留最近5天的日志。


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/674542


问题三:在Logback配置中,如何为名为"HSF"的logger指定一个特定的appender?

在Logback配置中,如何为名为"HSF"的logger指定一个特定的appender?


参考回答:

在Logback配置中,要为名为"HSF"的logger指定一个特定的appender,你可以在该logger的配置中通过<appender-ref>标签引用该appender。例如,如果你有一个名为"TOMS-HSF-APPENDER"的appender,你可以这样配置:

<logger name="HSF" level="${logback.info.level}" additivity="false"> 
<appender-ref ref="TOMS-HSF-APPENDER"/> 
</logger>


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/674543


问题四:如何在UnitConvertUtils工具类中实现米到千米的转换?

如何在UnitConvertUtils工具类中实现米到千米的转换?


参考回答:

在UnitConvertUtils工具类中,米到千米的转换可以通过将米数(以Long类型传入)除以米和千米的进率(RATE_OF_METRE_AND_KILOMETRE,值为1000d)来实现。如果输入为null,则方法返回null。转换方法如下:

public static Double convertMetre2Kilometre(Long toConvert) { 
if (toConvert == null) { 
return null; 
} 
return toConvert / RATE_OF_METRE_AND_KILOMETRE; 
}


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/674544


问题五:在Logback配置中,如何同时指定多个appender给同一个logger?

在Logback配置中,如何同时指定多个appender给同一个logger?


参考回答:

在Logback配置中,你可以通过在一个logger配置中多次使用<appender-ref>标签来同时指定多个appender给同一个logger。例如,对于名为"BIZ"的logger,你可以同时指定"TOMS-BIZ-APPENDER"和"TOMS-ERROR-APPENDER"两个appender:

<logger name="BIZ" level="${logback.info.level}" additivity="false"> 
<appender-ref ref="TOMS-BIZ-APPENDER"/> 
<appender-ref ref="TOMS-ERROR-APPENDER"/> 
</logger>


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/674545

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
6天前
|
Java 测试技术
Java接口的生产环境应用注意点
在Java生产环境中,合理使用接口对提升代码质量至关重要。设计接口时应遵循单一职责原则,采用清晰命名,并控制方法数量。默认方法应谨慎使用,避免与实现类产生冲突。通过版本化管理接口更新,确保向后兼容。实现接口时需明确行为,保持实现与接口分离,利用多态增强灵活性。关注性能影响,适当文档注释及充分测试确保接口稳定可靠。综合运用这些策略,可以显著提高系统的可扩展性和维护性。
|
6天前
|
Java 数据中心 微服务
Java高级知识:线程池隔离与信号量隔离的实战应用
在Java并发编程中,线程池隔离与信号量隔离是两种常用的资源隔离技术,它们在提高系统稳定性、防止系统过载方面发挥着重要作用。
6 0
|
8天前
|
Java 开发者 UED
Java中的异常处理机制:理解与应用
本文深入探讨Java的异常处理机制,通过实例解析如何有效使用try-catch-finally块、throws关键字及自定义异常,以提升代码的健壮性和可维护性。我们将从基础概念入手,逐步过渡到高级应用,为Java开发者提供全面指导。
|
2月前
|
Kubernetes Ubuntu Windows
【Azure K8S | AKS】分享从AKS集群的Node中查看日志的方法(/var/log)
【Azure K8S | AKS】分享从AKS集群的Node中查看日志的方法(/var/log)
|
23天前
|
Java
日志框架log4j打印异常堆栈信息携带traceId,方便接口异常排查
日常项目运行日志,异常栈打印是不带traceId,导致排查问题查找异常栈很麻烦。
|
1月前
|
存储 监控 数据可视化
SLS 虽然不是直接使用 OSS 作为底层存储,但它凭借自身独特的存储架构和功能,为用户提供了一种专业、高效的日志服务解决方案。
【9月更文挑战第2天】SLS 虽然不是直接使用 OSS 作为底层存储,但它凭借自身独特的存储架构和功能,为用户提供了一种专业、高效的日志服务解决方案。
66 9
|
2月前
|
开发框架 .NET Docker
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
|
2月前
|
存储 监控 安全
|
2月前
|
XML Java Maven
log4j 日志的简单使用
这篇文章介绍了Log4j日志框架的基本使用方法,包括在Maven项目中添加依赖、配置`log4j.properties`文件以及在代码中创建和使用Logger对象进行日志记录,但实际打印结果中日志级别没有颜色显示。
log4j 日志的简单使用
|
2月前
|
XML Java Maven
Spring5入门到实战------16、Spring5新功能 --整合日志框架(Log4j2)
这篇文章是Spring5框架的入门到实战教程,介绍了Spring5的新功能——整合日志框架Log4j2,包括Spring5对日志框架的通用封装、如何在项目中引入Log4j2、编写Log4j2的XML配置文件,并通过测试类展示了如何使用Log4j2进行日志记录。
Spring5入门到实战------16、Spring5新功能 --整合日志框架(Log4j2)
下一篇
无影云桌面