草庐IT

java - 在 log4j 中使用系统属性或变量

我想这样做:注意这一行:我试着像这样设置值:publicstaticvoidmain(String[]args){System.setProperty("error.log.path","/test/crm/log/error.log");ApplicationContextcontext=newClassPathXmlApplicationContext("blah.xml");....................}但我没有看到任何效果。是否在调用main之前配置了log4j?方法?还有其他方法吗? 最佳答案 看thisthr

java - 使用 tomcat 6 的 spring webapp 中的 Commons Logging/Log4j 设置问题

我在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

java - 我如何正确地使用 Log4j,关闭所有 Appender 并因此关闭文件

我的基于servlet的web应用程序在重新部署时有时无法关闭Log4j日志文件,泄漏到文件描述符泄漏并偶尔导致servlet包含的死于“太多打开的文件”。我有一个ContextListener,我应该在它的contextDestroyed()中放入什么来告诉log4j关闭并释放所有资源?快速浏览javadocs揭示了带有shutdown()方法的Hierachery类。我不知道如何实际获取当前的Hierachery,并且javadoc声明此类内部没有用户可服务的组件:) 最佳答案 试试这个:org.apache.log4j.Log

java - LOG4J:使用自定义附加程序修改记录的消息

出于安全原因,我需要查看我的应用程序中的每条记录消息,并可能在将其转到日志文件之前对其进行修改。我想我可以编写一个自定义附加程序(扩展DailyRollingFileAppender)并覆盖subAppend(LoggingEvent事件)。问题是,LoggingEvent中的消息文本没有setter,消息是私有(private)属性。我可以用我修改过的消息创建一个新的LoggingEvent,但是API不容易复制原始LoggingEvent的其余部分。这一切似乎都是为了阻止在自定义附加程序中干预消息。我能看到的唯一其他选项是修改数百个日志记录语句以调用一个新的全局方法,该方法可以先修

java - 如何指定 Log4J 2.x 配置位置?

有什么方法可以手动指定Log4J2.xlog4j2.xml文件位置(如Log4J1.x中的DOMConfigurator),而不会弄乱类路径和系统属性? 最佳答案 您可以在org.apache.logging.log4j.core.config中使用静态方法#initialize(StringcontextName,ClassLoaderloader,StringconfigLocation)(参见源代码here).配置器。(您可以为类加载器传递null。)请注意,此类不是公共(public)API的一部分,因此您的代码可能会因任何

java - 使用 JAR 加载 log4j.properties

这个问题在这里已经有了答案: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

java - Neo4j 和 ORM( hibernate )

我从大学开始就一直在使用RDBMS,我真的挣扎NoSQL数据库的基本概念......但我认为他们的概念真的很酷。我相信我理解以下内容(如果我错了,请纠正我,因为这些在我的问题中起作用!):NoSQL不是某种正式规范;这是一个新的“品种”数据库的概念,这些数据库不是关系型的,也不使用SQL因此,每个NoSQL系统都是不同的(例如,MongoDB是以JSON为中心的)如果这些都是真的,那么让我们将注意力转向“基于图形”的数据库Neo4j。仔细阅读该站点和PDF后,Neo4j似乎不仅是一个数据库,而且还提供了一个JavaAPI,基本上取代了对Hibernate等传统ORM工具的需求。因此,我

java - 有没有一种方法可以使用 SLF4J 样式的格式化函数来构建 Java 字符串?

我听说使用StringBuilder比使用字符串连接更快,但我厌倦了一直与StringBuilder对象较劲。我最近接触了SLF4J日志库,与String.format相比,我喜欢它的格式“只做正确的事”的简单性。有没有一个图书馆可以让我写这样的东西:intmyInteger=42;MyObjectmyObject=newMyObject();//OverridestoString()Stringresult=CoolFormatingLibrary.format("Simplewaytoformat{}and{}",myInteger,myObject);此外,是否有任何原因(包括性

java - Log4j - org.hibernate.type 不起作用!

这是我的记录器配置: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.

java - log4j 的生产设置文件?

这是我当前的log4j设置文件。这些设置是否适合生产使用,或者我应该删除/调整或更改哪些设置?我问是因为我的所有线程都由于log4j阻塞而被挂起。我检查了打开的文件描述符,我只使用了113。#*****SetrootloggerleveltoWARNanditstwoappenderstostdoutandR.log4j.rootLogger=warn,stdout,R#*****stdoutissettobeaConsoleAppender.log4j.appender.stdout=org.apache.log4j.ConsoleAppender#*****stdoutusesPa