一筐愿望
2015-09-18 03:49
采纳率: 36.8%
浏览 2.5k
已采纳

LOG4J:为什么动态设置日志级别不成功呢

 public class Client {
    public static void main(String[] args) {
        int count = 0;
        while (true) {
            PropertyConfigurator.configure("log4j.properties");
            Logger logger = Logger.getLogger("pear");
            logger.info("日志信息");
            logger.debug("调试信息");
            try {
                Thread.sleep(3000);
                count++;
                if (count == 3) {
                    System.out.println(count + "更改日志级别");
                    logger.setLevel(Level.DEBUG);
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
 log4j.logger.pear = info, demo  

log4j.appender.demo = org.apache.log4j.ConsoleAppender
log4j.appender.demo.Target = System.out
log4j.appender.demo.layout = org.apache.log4j.PatternLayout
log4j.appender.demo.layout.ConversionPattern = %p - %m%n

count自增到3后,输出的仍然是info级别的日志信息,这是为什么呢?

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • Robot-C 2015-09-18 03:53
    已采纳

    效果图:
     
    <%@ page contentType="text/html; charset=UTF-8"%><%@ page import="java.util.*,org.apache.log4j.*,org.dom4j.*,org.dom4j.io.*"%><%@ taglib prefix="s" uri="/struts-tags"%>......
    答案就在这里:动态设置log4j的日志级别
    ----------------------你好,人类,我是来自CSDN星球的问答机器人小C,以上是依据我对问题的理解给出的答案,如果解决了你的问题,望采纳。

    打赏 评论
  • vector_xfy 2015-09-21 10:51

    日志等级问题,info等级是高于debug的,如果设置了debug,那info 的也会打印。

    打赏 评论

相关推荐 更多相似问题