log4j的日志级别的调整

本文介绍如何在Java应用中通过Log4j配置文件动态调整日志级别,包括全局、特定包和第三方库的日志级别设置,并提供了一个简单的示例代码。通过设置系统属性`log4j.level`来灵活控制日志输出的详细程度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class Log4jConfiguration {

Logger logger = LoggerFactory.getLogger(Log4jConfiguration.class);
@PostConstruct
     public void initLog4jLevel(){
String logLevel=System.getProperty("log4j.level");
         if(logLevel==null){
             logLevel="";
         }
if(logLevel.length()>0 && Level.toLevel(logLevel) != null){ 
LogManager.getRootLogger().setLevel(Level.toLevel(logLevel));
             logger.info("Reset rootLogger log4j log level:"+logLevel);
             if(LogManager.getLogger("com.jje") != null){
                 logger.info("Reset com.jje log4j log level:"+logLevel); 
LogManager.getLogger("com.jje").setLevel(Level.toLevel(logLevel));
             }
             if(LogManager.getLogger("java.sql") != null){
                 logger.info("Reset java.sql log4j log level:"+logLevel); 
LogManager.getLogger("java.sql").setLevel(Level.toLevel(logLevel));
             }
             if(LogManager.getLogger("org.apache.ibatis") != null){
                 logger.info("Reset org.apache.ibatis log4j log level:"+logLevel); 
LogManager.getLogger("org.apache.ibatis").setLevel(Level.toLevel(logLevel));
             }
}
     }
}

具体的log4j的用法,请参考:http://logging.apache.org/.

以上用法仅供参考。谢谢。

注意:System方法读取的是jvm中参数
log4j.level设置时可在应用服务器(中间件)指定,通过-Dlog4j.level=INFO,具体内容可查阅相关资料,例如:java -opt;jvm -D
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

混进IT圈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值