关于Logback的一个异常
java.lang.NoSuchMethodError: org.slf4j.helpers.MessageFormatter.arrayFormat(Ljava/lang/String;[Ljava/lang/Object;)Lorg/slf4j/helpers/FormattingTuple;
原因可能有两个:
1、jar包冲突,build path下可能加入了 slf4j-log4或者 log4j的jar包,删除即可。
2、jar包版本导致的,例如 如果你的Logback是1.0.6版本,那么你的slf4j需要[1.5.5, 1.5.6, 1.5.7, 1.5.8, 1.5.9, 1.5.10, 1.5.11]版本的。
SLF4J: The requested version 1.6 by your slf4j binding is not compatible with [1.5.5, 1.5.6, 1.5.7, 1.5.8, 1.5.9, 1.5.10, 1.5.11]
不管是Logback版本高还是slf4j的低只要找对匹配的版本即可。
=====问题1:=========================================================================
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/data/elasticsearch/plugins/transport-thrift/slf4j-log4j12-1.6.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/data/elasticsearch/plugins/mapper-attachments/tika-app-1.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
产生原因:在slf4j-log4j12-1.6.2.jar和tika-app-1.1.jar里都有SLF4J,重复了
解决方法:我是把slf4j-log4j12-1.6.2.jar改成了slf4j-log4j12-1.6.2.jar.bak,也就是让此jar包失效
======问题2:==========================================================================
SLF4J: The requested version 1.5.6 by your slf4j binding is not compatible with [1.6]
产生原因:tika-app-1.1.jar里面包含了一个SLF4J的旧版本的class
解决方法:把tika-app-1.1.jar改成tika-app-1.1.jar.bak,也是让jar包失效
=======问题3========================================================================
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
产生原因:上面的两个jar文件被失效了,所以在调用的时候报错
解决方法:干脆把这两个插件都删掉【transport-thrift和mapper-attachments】