java - log4j配置与jboss7问题

标签 java spring log4j jboss7.x

java代码

 public static synchronized void init(String log4jXMLPath) //throws ServletException
   {
      try
      {
         if (!initialized) // set the global RepositorySelector
         {
            defaultRepository = LogManager.getLoggerRepository();
            RepositorySelector theSelector = new AppRepositorySelector();
            **LogManager.setRepositorySelector(theSelector, guard);**
            initialized = true;
         }
         Hierarchy hierarchy = new Hierarchy(new RootLogger(Level.DEBUG));
         //loadLog4JConfig(servletContext, hierarchy);
         loadLog4JConfig(hierarchy, log4jXMLPath);
         ClassLoader loader = Thread.currentThread().getContextClassLoader();
         repositories.put(loader, hierarchy);
      }
      catch (Exception e)
      {

         e.printStackTrace();
      }
   }

LogManager.setRepositorySelector(theSelector, Guard); java 代码中的这一行抛出错误

堆栈跟踪

18:17:11,189 ERROR [stderr] (MSC service thread 1-2) java.lang.IllegalArgumentException: Attempted to reset the LoggerFactory without possessing the guard.
18:17:11,190 ERROR [stderr] (MSC service thread 1-2)   at org.apache.log4j.LogManager.setRepositorySelector(LogManager.java:164)
18:17:11,191 ERROR [stderr] (MSC service thread 1-2)   at com.mportal.logger.api.AppRepositorySelector.init(AppRepositorySelector.java:73)
18:17:11,192 ERROR [stderr] (MSC service thread 1-2)   at com.mportal.logger.api.MPLoggerImpl.loadLogInstance(MPLoggerImpl.java:64)
18:17:11,192 ERROR [stderr] (MSC service thread 1-2)   at com.mportal.logger.api.MPLoggerImpl.<init>(MPLoggerImpl.java:38)
18:17:11,192 ERROR [stderr] (MSC service thread 1-2)   at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
18:17:11,193 ERROR [stderr] (MSC service thread 1-2)   at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
18:17:11,194 ERROR [stderr] (MSC service thread 1-2)   at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
18:17:11,194 ERROR [stderr] (MSC service thread 1-2)   at java.lang.reflect.Constructor.newInstance(Constructor.java:513)

如何解决这个问题?请给出解决方案。

最佳答案

LogManager.setRepositorySelector(theSelector, guard);

只能使用一个守卫,使用不同的守卫对象会导致观察者错误:

java.lang.IllegalArgumentException: Attempted to reset the LoggerFactory without possessing the guard.

应该可以将 null 作为参数传递给函数。或者简单地保存对初始设置防护的引用。

文档指出:

最初守卫为空。如果守卫为空,则调用此方法将设置记录器工厂和守卫。以下调用将抛出 IllegalArgumentException,除非之前设置的防护作为第二个参数传递。

关于java - log4j配置与jboss7问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13879600/

相关文章:

java - 3.0 servlet 中的 Log4J2 配置

java - 在 Google App Engine 上使用 log4j

java - 尝试一次只运行 5 个线程的 selenium webdriver,重复直到运行 200 个线程

java - 当我创建事件时,实现 ApplicationListener 接口(interface)的类不会启动

java - 如何使用 Apache POI 锁定 docx 中图像的长宽比?

spring - 如何让Spring MVC下载文件时弹出 "Save As"窗口?

spring - Hadoop Mapper 中的依赖注入(inject)

Java slf4j实现: logback vs log4j

java - 如何为每个节点指定唯一的名称

java - NoSuchBeanDefinition异常 : No qualifying bean of type 'org.springframework.mail.MailSender'