草庐IT

SystemOutToSlf4j

全部标签

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 - 如何更新或更改密码 neo4j 中的值

cypher中是否有任何更新查询,我们可以使用它来更新任何节点或关系的属性?例如我有以下节点和关系:NodeA-[r:relatedTo]-NodeB其中,relatedTo是具有active或inactive等属性的关系如何使用密码查询更改此属性? 最佳答案 使用SET密码查询中的关键字,请参见http://docs.neo4j.org/chunked/snapshot/query-set.html.(因为我没有像其他RDBMS那样在cypher中遇到任何更新查询)节点A-[r:relatedTo]-节点B尝试通过以下方式设置值:

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

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

java - SLF4J 和 Logback 的依赖管理

我想开始将SLF4J与Logback结合使用。我在网上阅读了Logback的documentation现在我准备将JAR添加到我的存储库中并进行试用。但是我很茫然!我需要什么JAR?我下载了最新的SLF4J(1.7.5),希望看到somethingslf4j-logback.jar之类的东西,但没有看到任何类似的东西。我读过Logback包含SLF4J的“native实现”,但不知道这到底是什么意思,或者它是否也暗示我什至不需要slf4j-api-1.7.5.jar在类路径上。所以我问:要使用最新的Logback(1.0.13),我需要什么JAR?我看了一下Maven中央仓库forlo

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 - Maven 错误 - java.lang.NoClassDefFoundError : org/slf4j/helpers/MarkerIgnoringBase

启动并运行Maven。尝试构建一个我继承的项目。我已经解决了大部分问题,但现在看到一个奇怪的错误:[INFO]------------------------------------------------------------------------[INFO]BUILDFAILURE[INFO]------------------------------------------------------------------------[INFO]Totaltime:2.842s[INFO]Finishedat:2015-04-24T13:59:32+01:00[INFO]Fin

java - 格式化 slf4j 以记录带有颜色的消息类型

我正在使用slf4j登录我的Java应用程序。它涉及很多日志记录和日志监控。当整个日志以黑色打印时,有时真的很难阅读和查找日志中的信息。只是为了使其更具可读性,是否可以用不同颜色记录不同类型的消息?例如,所有红色或不同字体大小的错误级别消息以及蓝色和不同字体大小的所有信息级别消息。欢迎任何建议或帮助。谢谢。 最佳答案 无法更改slf4j日志记录的颜色,因为没有格式化程序。SLF4J是您的应用程序和某些日志记录工具(例如Log4j或Logback)之间的中间件。您可以更改Log4j输出中的颜色,如here所述.我建议使用Multico