我按照 Hazelcast 文档使用以下链接支持 Log4J:
https://docs.hazelcast.org/docs/latest/manual/html-single/#logging-configuration
但即使这样做了,我也无法获得 Hazelcast 日志。
查询:
- 我们是否明确需要添加 log4j-1.2.17.jar 文件并将此依赖项添加到 pom.xml 文件中? 如果是 请让我知道 Hazelcast 文档中缺少什么
- 是否可以排除故障并检查错误是什么?
在您分享的 Hazelcast 参考手册部分中有一个注释。它解释了这件事:
如果选择使用
log4j
、log4j2
或slf4j
,则应在类路径中包含正确的依赖关系。
意思是,是的。如果使用与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.type
如log4j
表示 Hazelcast 使用它在运行时找到的任何 Log4j,因为这使您能够选择所需的版本。
所以你的pom需要构建一个可执行的Jar,至少包括Hazelcastjar和Log4j jar。或者,将两者放在运行时的类路径上。
对我来说,3.12.5 立即失败
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger
如果我请求 Log4j但没有在运行时类路径上提供 Log4j jar。如果你 不要收到该消息,可能是您指定的配置未被使用。