Hazelcast IMDG 3.12.5 添加了 log4j 依赖项以支持日志记录



我按照 Hazelcast 文档使用以下链接支持 Log4J:

https://docs.hazelcast.org/docs/latest/manual/html-single/#logging-configuration

但即使这样做了,我也无法获得 Hazelcast 日志。

查询:

  1. 我们是否明确需要添加 log4j-1.2.17.jar 文件并将此依赖项添加到 pom.xml 文件中? 如果是 请让我知道 Hazelcast 文档中缺少什么
  2. 是否可以排除故障并检查错误是什么?

在您分享的 Hazelcast 参考手册部分中有一个注释。它解释了这件事:

如果选择使用log4jlog4j2slf4j,则应在类路径中包含正确的依赖关系。

意思是,是的。如果使用与java.util.logging不同的日志记录框架,则必须自己提供实现。

如果未提供正确的实现,节点将无法启动:

java -Dhazelcast.logging.type=log4j -jar 
~/.m2/repository/com/hazelcast/hazelcast/3.12.5/hazelcast-3.12.5.jar 
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger
at com.hazelcast.logging.Log4jFactory.createLogger(Log4jFactory.java:29)
at com.hazelcast.logging.LoggerFactorySupport$1.createNew(LoggerFactorySupport.java:32)
at com.hazelcast.logging.LoggerFactorySupport$1.createNew(LoggerFactorySupport.java:30)
at com.hazelcast.util.ConcurrencyUtil.getOrPutIfAbsent(ConcurrencyUtil.java:125)
at com.hazelcast.logging.LoggerFactorySupport.getLogger(LoggerFactorySupport.java:38)
at com.hazelcast.logging.Logger.getLogger(Logger.java:110)
at com.hazelcast.logging.Logger.getLogger(Logger.java:64)
at com.hazelcast.instance.HazelcastInstanceFactory.<clinit>(HazelcastInstanceFactory.java:67)
at com.hazelcast.core.Hazelcast.newHazelcastInstance(Hazelcast.java:91)
at com.hazelcast.core.server.StartServer.main(StartServer.java:46)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger
at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:352)
at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
... 10 more

log4j自 5 年前就已弃用,存在安全漏洞,可能无法在较新版本的 Java 上运行。看这里。

指定hazelcast.logging.typelog4j表示 Hazelcast 使用它在运行时找到的任何 Log4j,因为这使您能够选择所需的版本。

所以你的pom需要构建一个可执行的Jar,至少包括Hazelcastjar和Log4j jar。或者,将两者放在运行时的类路径上。

对我来说,3.12.5 立即失败

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger

如果我请求 Log4j但没有在运行时类路径上提供 Log4j jar。如果你 不要收到该消息,可能是您指定的配置未被使用。

相关内容

最新更新