Tag: slf4j

Java:如何将原始JSON记录为JSON,并避免在使用logback / slf4j进行日志记录期间转义

我在JAX-RS应用程序中使用带有Logback的SLF4J …我想以这样的方式登录到JSON,即我的消息不再被编码,而是原始打印到日志文件中: 目前它看起来像这样: {“@timestamp”:1363834123012,”@message”:”{\”text\”:\”From MLK to Barack Ob…\n\”}” 但我希望有这个: {“@timestamp”:1363834123012,”@message”: { “text “: “From MLK to Barack Ob…\n\} 原因是我想再次解析JSON并希望避免数据的转义。 我写了一个自定义的logback编码器,但我发现无法避免转义。 我可以传递对象进行回溯并根据对象的类型更改设置吗? 编辑:我找到了一种方式 – 不完全优雅 – 按照SSCE的要求: 在我的申请中 // SLF4J Logger private static Logger logger = LoggerFactory.getLogger(MyClass.class); // A logback? Marker private Marker foo = MarkerFactory.getMarker(“foo”); // Jackson ObjectMapper() ObjectMapper mapper = new ObjectMapper(); // Log […]

是否存在使用消息参数作为属性创建JSON对象的Logback布局?

我想将日志事件作为带有参数化字符串消息的JSON对象发送到Loggly。 我们的项目目前有很多代码如下: String someParameter = “1234”; logger.log(“This is a log message with a parameter {}”, someParameter); 我们目前正在使用Logback作为我们的SLF4J后端,而Logback的JsonLayout将我们的ILogEvent对象序列化为JSON。 因此,当我们将日志事件发送到Loggly时,它们看起来像这样: { “message”: “This is a log message with a parameter 1234”, “level”: INFO, …. } 虽然这确实有效,但它会为someParameter每个值发送一个不同的message字符串,这会使Loggly的自动filter无效。 相反,我想要一个创建如下所示的JSON的布局: { “message”: “This is a log message with a parameter {}”, “level”: INFO, “parameters”: [ “1234” ] } 这种格式允许Loggly使用消息对所有日志事件进行分组。 This […]

登录lobgack时如何处理磁盘已满错误?

我正在使用slf4j + logback登录我们的应用程序。 早些时候我们使用jcl + log4j并最近移动了。 由于我们的应用程序中存在大量日志记录,因此在生产环境中磁盘可能已满。 在这种情况下,我们需要停止记录,应用程序应该正常工作。 我在网上发现的是我们需要轮询logback StatusManager以查找此类错误。 但是这将为应用程序添加一个依赖项和logback。 对于log4j,我发现我们可以创建一个Appender来停止在这种情况下登录。 这将再次导致与log4j的应用程序依赖。 有没有办法只用slf4j配置它,还是有其他机制来处理这个?

如何关闭slf4j的日志记录

这是第三方应用程序在我们的应用程序服务器上生成大量的logentries。 喜欢这个: [03.03.10 15:21:57:250 CET] 00000180 FtpProtocolHa I org.slf4j.impl.JCLLoggerAdapter info Close connection : 10.227.10.10 – admin [03.03.10 15:27:35:209 CET] 00000181 MinaFtpProtoc I org.slf4j.impl.JCLLoggerAdapter info [/10.227.10.10] CLOSED ++++ 如何关闭slf4j的输出? 我查看了.war文件,找到slf4j的一些配置,但没有。 他们的网站也没有帮助

如何使用log4j 2.0和slf4j以及Commons一起登录

我目前正在开始一个新的Webapp(在tomcat 6上运行)我有使用slf4j的组件和使用commons日志记录的组件我计划使用log4j 2.0作为日志实现由于几个原因(主要用于appender:SocketAppender和SyslogAppender但也因为提升配置重新加载而不丢失日志事件) 现在我的问题是: – 我可以为哪些界面编写新课程? loag4j还是slf4j? 甚至公共伐木? 什么是部署jar子的首选方式? 把它们放在我的应用程序大战中还是我把它们放到tomcat库中? 我需要部署哪些jar子? log4j(包括slf4j和commons绑定),commons logging(slf4j-api-1.7.2.jar)和slf4j api(slf4j-api-1.7.2.jar)

Spring Boot:多个SLF4J绑定

这可能是一个重复的问题,但我无法弄清楚绑定碰撞在哪里。 我有我的Spring Boot 1.2.6.RELEASE服务,当我运行它时我收到此错误: SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/home/jscherman/.m2/repository/ch/qos/logback/logback-classic/1.1.3/logback-classic-1.1.3.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: Found binding in [jar:file:/home/jscherman/.m2/repository/org/slf4j/slf4j-log4j12/1.7.12/slf4j-log4j12-1.7.12.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. SLF4J: Actual binding is of type [ch.qos.logback.classic.util.ContextSelectorStaticBinder] 这是mvn dependency:tree输出 [INFO] com.myenterprise:product-manager:jar:0.0.1-SNAPSHOT [INFO] +- com.myenterprise.product:myproject-api:jar:0.0.1-SNAPSHOT:compile [INFO] +- com.myenterprise.product:myproject-core:jar:0.0.1-SNAPSHOT:compile [INFO] +- org.springframework.boot:spring-boot-starter-web:jar:1.2.6.RELEASE:compile [INFO] | +- org.springframework.boot:spring-boot-starter-tomcat:jar:1.2.6.RELEASE:compile [INFO] | | +- […]

用于Java的简单日志外观和Apache Commons日志记录之间的区别

Simple Logging Facade for Java和Apache Commons Logging有什么区别?

log4j,slf4j和logback有什么区别?

我对这三个记录器库有点困惑。 看起来他们可以在java日志记录中做类似的事情……

如何在Java中实现API / SPI模式?

我正在创建一个框架,公开API供开发人员使用: public interface MyAPI { public void doSomeStuff(); public int getWidgets(boolean hasRun); } 所有开发人员应该做的是根据这些API方法编写项目代码。 我还希望他们能够在运行时类路径上放置不同的“驱动程序”/“API绑定”(与JDBC或SLF4J的工作方式相同),并让API方法调用( doSomeStuff()等)在不同的第三方上运行资源(文件,服务器等)。 因此,相同的代码和API调用将映射到不同资源上的操作,具体取决于运行时类路径所看到的驱动程序/绑定(即myapi-ftp , myapi-ssh , myapi-teleportation )。 如何编写(和打包)允许这种运行时绑定的SPI,然后将MyAPI调用映射到正确的(具体)实现? 换句话说,如果myapi-ftp允许你从FTP服务器getWidgets(boolean) ,我怎么能这样做(使用API​​和SPI)? 具体的工作Java代码示例的奖励点! 提前致谢!

Logback logger记录两次

我想在我的应用程序中使用slf4j + logback用于两个目的 – 日志和审计。 对于日志记录,我记录正常方式: static final Logger logger = LoggerFactory.getLogger(Main.class); logger.debug(“-> main()”); 对于Audit,我创建了一个特殊的命名记录器并记录到它: static final Logger logger = LoggerFactory.getLogger(“AUDIT_LOGGER”); Object[] params = { new Integer(1) /* TenantID */, new Integer(10) /* UserID */, msg}; logger.info(“{}|{}|{}”, params); logback配置: %d{HH:mm:ss.SSS}|%msg%n %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} – %msg%n 问题:通过审计记录器记录的消息出现两次 – 一次在AUDIT_LOGGER下,一次在根记录器下。 14:41:57.975 [main] DEBUG com.gammay.example.Main – – […]