我正在尝试使用JBossweld编写一个javaSEswing应用程序。Weld使用jar中的以下log4j.xml文件使用log4j配置日志记录:我想在我的应用程序中完全禁用日志记录。我试图通过提供一个log4j.properties文件来禁用它,如下所示:log4j.debug=FALSElog4j.rootLogger=OFF,CONSOLE无论我尝试做什么,都无法阻止来自Weld的log4j消息显示在控制台中。我想要做的就是完全禁用日志记录。但是如何呢? 最佳答案 在发布这个问题后不久,我找到了答案。创建一个log4j.xm
我想这样做:注意这一行:我试着像这样设置值:publicstaticvoidmain(String[]args){System.setProperty("error.log.path","/test/crm/log/error.log");ApplicationContextcontext=newClassPathXmlApplicationContext("blah.xml");....................}但我没有看到任何效果。是否在调用main之前配置了log4j?方法?还有其他方法吗? 最佳答案 看thisthr
我在tomcat6下部署的apringwebapp中的日志记录设置有问题。Web应用程序使用commons-loggingapi,在运行时应该使用log4j。日志文件已创建但仍为空-没有日志条目出现。设置如下:WEB-INF/web.xml:log4jConfigLocation/WEB-INF/log4j.xmlorg.springframework.web.util.Log4jConfigListenerWEB-INF/classes/commons-logging.properties:org.apache.commons.logging.Log=org.apache.commo
我的基于servlet的web应用程序在重新部署时有时无法关闭Log4j日志文件,泄漏到文件描述符泄漏并偶尔导致servlet包含的死于“太多打开的文件”。我有一个ContextListener,我应该在它的contextDestroyed()中放入什么来告诉log4j关闭并释放所有资源?快速浏览javadocs揭示了带有shutdown()方法的Hierachery类。我不知道如何实际获取当前的Hierachery,并且javadoc声明此类内部没有用户可服务的组件:) 最佳答案 试试这个:org.apache.log4j.Log
出于安全原因,我需要查看我的应用程序中的每条记录消息,并可能在将其转到日志文件之前对其进行修改。我想我可以编写一个自定义附加程序(扩展DailyRollingFileAppender)并覆盖subAppend(LoggingEvent事件)。问题是,LoggingEvent中的消息文本没有setter,消息是私有(private)属性。我可以用我修改过的消息创建一个新的LoggingEvent,但是API不容易复制原始LoggingEvent的其余部分。这一切似乎都是为了阻止在自定义附加程序中干预消息。我能看到的唯一其他选项是修改数百个日志记录语句以调用一个新的全局方法,该方法可以先修
有什么方法可以手动指定Log4J2.xlog4j2.xml文件位置(如Log4J1.x中的DOMConfigurator),而不会弄乱类路径和系统属性? 最佳答案 您可以在org.apache.logging.log4j.core.config中使用静态方法#initialize(StringcontextName,ClassLoaderloader,StringconfigLocation)(参见源代码here).配置器。(您可以为类加载器传递null。)请注意,此类不是公共(public)API的一部分,因此您的代码可能会因任何
这个问题在这里已经有了答案:Shouldlog4.propertiesbeontheclasspath?(6个答案)关闭6年前。我有一个包含以下list的jar文件Manifest-Version:1.0Created-By:1.7.0_07(OracleCorporation)Main-Class:test.MainClass-Path:./log4j.propertieslib/log4j-1.2.17.jar我按如下方式运行类java-jartest.jar这是我的文件夹liblog4j.propertiestest.jar为什么我看不到log4j属性文件?这是我看到的log4j
我在Windows7操作系统上安装了Apachetomcate。我刚刚安装了apache并使其在eclipse中可用。当我在服务器上运行任何简单的应用程序时,它会显示404:找不到页面,并且在控制台中它会打印这样的错误消息。SEVERE:Failedtoopenaccesslogfile[C:\ProgramFiles\ApacheSoftwareFoundation\Tomcat7.0\logs\localhost_access_log.2014-08-30.txt]java.io.FileNotFoundException:C:\ProgramFiles\ApacheSoftwar
这是我的记录器配置:log4j.logger.org.hibernate.SQL=TRACE,stdoutlog4j.logger.org.hibernate.type=TRACE,stdout但我没有看到类型bingings所以我试了一下log4j.logger.org.hibernate=TRACE,stdout看看我是否遗漏了什么(这显示了所有hibernate记录器)我发现org.hibernate.engine.QueryParameters记录器也显示参数绑定(bind)(仍然没有org.hibernate.type记录器绑定(bind)消息的迹象)然后我尝试了log4j.
这是我当前的log4j设置文件。这些设置是否适合生产使用,或者我应该删除/调整或更改哪些设置?我问是因为我的所有线程都由于log4j阻塞而被挂起。我检查了打开的文件描述符,我只使用了113。#*****SetrootloggerleveltoWARNanditstwoappenderstostdoutandR.log4j.rootLogger=warn,stdout,R#*****stdoutissettobeaConsoleAppender.log4j.appender.stdout=org.apache.log4j.ConsoleAppender#*****stdoutusesPa