草庐IT

exception-logging

全部标签

java - 如何将所有日志从 hibernate 和 spring 重定向到 log4j2?

我用下一个技术堆栈构建我的“superWebApp”:persistenceprovider-Hibernate4.xwebMvcandbeanscontainer-Spring4.xwebcontainter-Tomcat7.5.x我的任务是将所有日志写入数据库。分别为每个日志框架做这件事会很痛苦。这就是为什么我需要将所有日志重定向到单个框架,然后使用DBAppender就不成问题了。我在考虑log4j2,因为我用它在“superWebApp”中写入日志。那么是否知道如何将所有日志从hibernate和spring重定向到log4j2?(最好也重定向tomcat日志)?如果不可能,也

java - 好奇 : Why is the "throws <SomeSpecific>Exception" syntax required in Java alone?

我们都知道它是必需的。但是为什么仅在Java中需要它,而其他具有异常处理能力的类似语言不需要我们编写“throwsException”?有没有人知道在设计Java语言时发生了什么以及为什么要这样做?只是好奇。附言这可能不是一个实际或真正必要的问题-它可能对我正在进行的项目无论如何都没有帮助。但是某些语言特性激起了我的好奇心:D编辑看来我的问题很含糊!我想我错误地表达了这个问题。在处理Java代码的编程过程中,我们需要在某些时候使用“throwsException”类语法。但是在C#或C++甚至VB.Net和PHP中从来不需要类似的东西。那么为什么只有Java坚持这样做呢?

java - Log4j 单例包装器的好处?

我最近继承了一些Java代码,需要将其集成到我正在从事的项目中。我的项目是一个处理和转换XML消息的服务代理。在查看新代码时,我发现了以下日志记录类:importorg.apache.log4j.BasicConfigurator;importorg.apache.log4j.Level;importorg.apache.log4j.Logger;publicclassMyLogger{privatestaticMyLoggerinstance=null;protectedfinalstaticLoggerlog=Logger.getLogger(MyLogger.class);pri

java - Spring 框架 : instantiation exception

我是SpringFramework的新手,所以我决定买一本书(“Springinaction”第3版)。目前我在第一章,涵盖基础知识-依赖注入(inject)(DI)和面向方面的编程(AOP)。我设法运行了显示DI的代码。1#knight实现的接口(interface)packagecom.springinaction.knights;publicinterfaceKnight{voidembarkOnQuest()throwsQuestException;}1#骑士等级packagecom.springinaction.knights;publicclassBraveKnightim

java - Log4J:关闭 Hook 上的致命异常,无法弄清楚原因

我刚刚将log4j集成到我的应用程序中,并且我正在设置AspectJ以使用log4j并最终将所有登录转移出我的主代码。所以,简而言之,我正在设置执行日志条目的方面,然后在短时间内运行我的程序来测试它们。在这些短期运行期间,我经常遇到以下异常:2015-09-2815:21:48,222Thread-4FATALUnabletoregistershutdownhookbecauseJVMisshuttingdown.java.lang.IllegalStateException:Cannotaddnewshutdownhookasthisisnotstarted.Currentstate

java - 如何区分日志文件中的 log4j session 与同一 Web 应用程序的副本?

只有一个文件。它是在网络应用副本运行时同时编写的。如何从其他日志行中仅过滤一条session日志消息? 最佳答案 使用包含NDC或MDC信息的servlet过滤器是我见过的最佳方式。两者的快速比较可在http://wiki.apache.org/logging-log4j/NDCvsMDC获得。.我发现MDC过去对我来说效果更好。请记住,您需要更新log4j属性文件以包含您喜欢的任何版本(模式定义位于http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/Patter

java - 为什么 log4j 在(多次)重复相同异常后禁用堆栈跟踪?

在我们的一个客户安装中,我们遇到了数千次相同的异常。在大量记录良好的堆栈跟踪(9332)之后,仍然记录了异常的发生,但没有堆栈跟踪。重新启动java进程后,同样的事情:这次我们有17858个堆栈跟踪,然后只有异常发生本身。有个类似的问题here,但没有答案...这是log4j的特性还是错误?(我相信前者,因为我真的很喜欢那些apache家伙做的事)有什么想法吗? 最佳答案 使用Java5或更高版本?然后你会看到:ThecompilerintheserverVMnowprovidescorrectstackbacktracesfora

java - 如何在 JAVA 中查看完整的异常日志?

这个问题在这里已经有了答案:PrintfullcallstackonprintStackTrace()?(3个答案)关闭5年前。当我使用命令javaExceptionTest运行一些java程序时,异常有时会被省略,看起来像Exceptioninthread"main"java.lang.NoClassDefFoundError:aa/bb/DDatSOMEWHERE(unknownsource)Causedby:java.lang.ClassNotFoundException:aaa.bbb.CCatSOMEWHER(unknownsource)...13more在这种情况下,我希望

java - IntelliJ 13 Tomcat 配置类 org.springframework.web.util.Log4jConfigListener 的应用程序监听器时出错

我正在尝试使用IntelliJ13及其内置的Tomcat部署插件运行Java/Spring/Hibernate/Ivy应用程序。我使用的是Tomcat8.0.9,但我也尝试过使用Tomcat6.0.39。当我尝试启动Tomcat时,我正在创建一个工件;更具体地说,是一场爆炸性的war。我正在使用Ivy来解决我的依赖关系,这是因为它是一个不使用Maven的遗留应用程序。愚蠢,我知道。当尝试使用任何版本的Tomcat从IntelliJ内部运行此应用程序时,我在“服务器”日志中收到以下消息:C:\dev\apache-tomcat-6.0.39\apache-tomcat-6.0.39\bi

java - 如何在 log4j 文件名中插入当前 webapp 的文件夹名称

我正在编写一个要在Tomcat中部署的JavaWeb应用程序,并且我正在使用log4j进行日志记录。我喜欢在生成的日志文件的名称中自动插入Web应用程序的文件夹名称。目前log4j.properties中的文件名设置如下所示:log4j.appender.R.File=${catalina.home}/logs/mywebapp.log我需要这样的东西:log4j.appender.R.File=${catalina.home}/logs/${current.webapp.folder}.log是否需要在属性文件中为此指定某种环境变量,或者我必须从代​​码中实例化记录器?