草庐IT

log_partitioned

全部标签

java - log4j.properties 被忽略

我在glassfishv3.0.1上使用IntelliJIDEA9.0.3通过maven部署了一个JavaEE6Wicket应用程序。我将slf4j-log4j12-1.5.6与slf4j-api-1.5.8和log4j-1.2.16一起用于日志记录。当我通过netbeans或eclipse部署时,它以前工作正常,但是当我使用IntelliJIDEA部署时,我的log4j.properties文件被忽略,glassfish的日志记录处理我的日志消息。我不认为IDEA与它有任何关系,一定有其他东西改变了我只是想不通是什么。我已验证我的log4j.properties文件在我的WEB-IN

java - log4j 和线程上下文类加载器

我是Java的新手,刚刚开始了解类加载器的概念。现在我在使用log4j线程上下文类加载器时遇到了一些问题。我收到以下错误:“org.apache.log4j.ConsoleAppender”对象不可分配给“org.apache.log4j.Appender”变量。“org.apache.log4j.Appender”类由[java.net.URLClassLoader@105691e]加载,而“org.apache.log4j.ConsoleAppender”类型的对象由[sun.misc.Launcher$AppClassLoader@16930e2]加载.无法实例化名为“CONSO

java - Commons Logging优先级最佳实践

这可能是一个纯粹主观的问题(如果没有组织试图对此进行标准化),但我的团队在这方面的挣扎比你想象的要多。我们使用ApacheCommonsLogging作为我们的日志接口(interface),并且我们的开发团队对优先级的使用通常并不一致。例如,一些开发人员将任何捕获的异常记录为致命(log.fatal(message)),即使流程能够处理错误,而其他开发人员仅在某些原因导致程序因任何原因必然停止执行时才记录为致命。我想知道其他团队如何定义每个优先级。有没有人在明确尝试为此定义最佳实践的公司工作?Jakarta是否对此进行了权衡?我的目标是向我的整个团队发送针对每个优先级的简单建议,以便

java - Log4j,禁用依赖于环境的附加程序

我想要一个log4j.xml配置,并且能够在开发我的应用程序时登录到控制台。一旦部署到环境中,我只想登录到文件附加程序而不是控制台。我怎样才能做到这一点?这是我当前的配置: 最佳答案 解决方案之一可能是为开发和生产环境分离log4j配置文件,例如:log4j-development.xml-用于开发环境log4j-production.xml-用于生产环境然后您的应用程序启动命令可以有指定log4j配置文件的参数,例如java-Dlog4jconfig=log4j-development.xml-jarApplication.jar

java - 使用 log4j 以编程方式创建不同的日志文件

我有一个自动化集成测试工具,想简化日志记录(使用log4j实现)我有许多高级测试,每个测试都有一个ID,并且每个测试都需要一个单独的日志文件。由于测试是随机创建的,因此直到运行时才知道ID。因此,我想确保每个高级测试中的日志记录都写到该测试的日志文件中。我不想创建自定义日志级别,我也不想将日志记录发送到所有附加程序。有人知道这样做的方法吗? 最佳答案 您可以轻松地以编程方式调用log4j的API,例如FileAppenderappender=newFileAppender();//configuretheappenderhere,w

java - 如何在 SLF4j 或 Log4J 中动态更改日志级别

最近遇到一个ApplicationLoglevel动态变化的情况。应用程序管理员可以从前端将其设置为INFO/DEBUG/WARN。根据选择的日志级别,必须更改应用程序日志记录。我确信记录器支持这种情况。我怎样才能做到这一点? 最佳答案 无法在slf4j中动态更改日志级别,但slf4j的一些后端支持它,包括log4j。这个解决方案对我有用:org.apache.log4j.Loggerlogger4j=org.apache.log4j.Logger.getRootLogger();logger4j.setLevel(org.apac

java - 如何正确关闭 log4j2

如果没有在Web应用程序中运行,关闭Log4j2的正确方法是什么?我只看到一个noopLogManager.shutdown() 最佳答案 没有公共(public)API,但您可以使用((LifeCycle)LogManager.getContext()).stop();如果您有兴趣为此提供公共(public)API,请在此处投票或添加评论:https://issues.apache.org/jira/browse/LOG4J2-124更新:在Log4j2.5中,您可以调用Configurator.shutdown()。使用Log4

java - 使用 jetty 和 log4j 2.9.1 扫描条目 META-INF/versions/9/org/apache/logging/log4j/util/StackLocator.class 时出错?

这是我在我的maven项目中的目录布局:.├──pom.xml└──src└──main├──java│  └──biz│  └──tugay│  └──web│  └──servlet│  └──MainServlet.java├──resources│  └──log4j.properties└──webapp└──WEB-INF└──web.xmlpom.xml相关部分如下:javax.servletjavax.servlet-api3.1.0providedorg.apache.logging.log4jlog4j-core${log4j.version}runtimeorg.

java - log4j 日志文件名?

我们有几个同时运行的作业,它们必须为log4j使用相同的配置信息。他们都使用相同的附加程序将日志转储到一个文件中。有没有办法让每个作业动态命名其日志文件,以便它们保持独立?谢谢汤姆 最佳答案 您可以为每个作业传递一个Java系统属性吗?如果是这样,您可以像这样进行参数化:java-Dmy_var=somevaluemy.job.Classname然后在您的log4j.properties中:log4j.appender.A.File=${my_var}/A.log您可以使用来自主机环境(例如)的值填充Java系统属性,该值将唯一标识

java - 大哦 (n log n)

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预期结果。另请参阅:StackOverflowquestionchecklist关闭9年前。Improvethisquestion我目前正在研究BigOh的基本算法。我想知道是否有人可以告诉我使用BigOh的Java中(nlogn)的代码是什么样的,或者将我定向到任何存在的SO页面。由于我只是一个初学者,所以我在编写代码之前只能想象一下代码。因此,理论上(至少),它应该包含一个for循环,其中我们有n