Java - OSX Mavericks 上的 Accumulo init 异常 - log4j 记录器

标签 java macos exception logging accumulo

我正在尝试让 Accumulo 在 OSX Mavericks 上工作。我有 Java 1.8,并通过 Homebrew 安装了最新的 Zookeeper 和 Hadoop。这两个似乎都工作正常。

我下载了 Accumulo 的二进制文件,并在 accumulo/conf/accumulo-env.sh 中编辑了这些行:

test -z "$HADOOP_PREFIX"      && export HADOOP_PREFIX=/usr/local/Cellar/hadoop/2.4.0
test -z "$HADOOP_CONF_DIR"     && export HADOOP_CONF_DIR="$HADOOP_PREFIX/libexec/etc/hadoop"
test -z "$JAVA_HOME"             && export JAVA_HOME=$(/usr/libexec/java_home)
test -z "$ZOOKEEPER_HOME"        && export ZOOKEEPER_HOME=/usr/local/Cellar/zookeeper/3.4.6

但是,当我运行 bin/accumulo init 时,我得到:

$ bin/accumulo init
Uncaught exception: java.lang.NoClassDefFoundError: org/apache/log4j/Logger
java.lang.NoClassDefFoundError: org/apache/log4j/Logger
    at org.apache.accumulo.start.classloader.AccumuloClassLoader.<clinit>(AccumuloClassLoader.java:78)
    at org.apache.accumulo.start.Main.main(Main.java:39)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 2 more

我找不到任何有用的搜索结果。我不确定什么配置不当会导致此类错误,所以我不知道从哪里开始。

我没有对 Zookeeper 或 Hadoop 的配置进行任何更改,因此 Hadoop 处于基本的独立模式,我已通过他们的示例之一确认该模式正在工作。 Zookeeper 使用 zkServer 正确启动/停止。所以我猜测问题出在我的 Accumulo 配置中。不幸的是,他们的自述文件对我的情况根本没有帮助,基本上只是告诉我,我下载的 Accumulo 二进制文件应该开箱即用。

我尝试使用设置和未设置的环境变量 JAVA_HOME 运行它,并在 Accumulo-env.sh 中明确定义它。

感谢您为我指明正确方向的任何事情。我的最终目标实际上是修补 GeoMesa,这取决于 Accumulo 的工作。

最佳答案

配置 Accumulo 时,您是否编辑了 conf/accumulo-site.xml

我假设您使用的是 Accumulo 1.5.1,看起来您使用的是 Hadoop 2.4.0。在 conf/accumulo-site.xml 内部,您需要向 general.classpaths 属性添加一些路径,以获取 Hadoop 使用的所有 JAR。

以下是 general.classpaths 的属性应如下所示:

<property>
  <name>general.classpaths</name>
  <!--
     Add the following for Hadoop2, actual needs depend on Hadoop installation details. 
     This list may be excessive, but this should cause no issues. Append these values
     after the $HADOOP_PREFIX entries

     $HADOOP_PREFIX/share/hadoop/common/.*.jar,
     $HADOOP_PREFIX/share/hadoop/common/lib/.*.jar,
     $HADOOP_PREFIX/share/hadoop/hdfs/.*.jar,
     $HADOOP_PREFIX/share/hadoop/mapreduce/.*.jar,
     $HADOOP_PREFIX/share/hadoop/yarn/.*.jar,
     /usr/lib/hadoop/.*.jar,
     /usr/lib/hadoop/lib/.*.jar,
     /usr/lib/hadoop-hdfs/.*.jar,
     /usr/lib/hadoop-mapreduce/.*.jar,
     /usr/lib/hadoop-yarn/.*.jar,
  -->
  <value>
    $ACCUMULO_HOME/server/target/classes/,
    $ACCUMULO_HOME/lib/accumulo-server.jar,
    $ACCUMULO_HOME/core/target/classes/,
    $ACCUMULO_HOME/lib/accumulo-core.jar,
    $ACCUMULO_HOME/start/target/classes/,
    $ACCUMULO_HOME/lib/accumulo-start.jar,
    $ACCUMULO_HOME/fate/target/classes/,
    $ACCUMULO_HOME/lib/accumulo-fate.jar,
    $ACCUMULO_HOME/proxy/target/classes/,
    $ACCUMULO_HOME/lib/accumulo-proxy.jar,
    $ACCUMULO_HOME/lib/[^.].*.jar,
    $ZOOKEEPER_HOME/zookeeper[^.].*.jar,
    $HADOOP_CONF_DIR,
    $HADOOP_PREFIX/[^.].*.jar,
    $HADOOP_PREFIX/lib/[^.].*.jar,

    <!-- Added for Hadoop 2 -->
    /usr/lib/hadoop/.*.jar,
    /usr/lib/hadoop/lib/.*.jar,
    /usr/lib/hadoop-hdfs/.*.jar,
    /usr/lib/hadoop-mapreduce/.*.jar,
    /usr/lib/hadoop-yarn/.*.jar,
  </value>
  <description>Classpaths that accumulo checks for updates and class files.
    When using the Security Manager, please remove the ".../target/classes/" values.
  </description>
</property>

配置完成后,应该可以找到 log4j。

关于Java - OSX Mavericks 上的 Accumulo init 异常 - log4j 记录器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23583579/

相关文章:

Mac OS 上的 Android Studio IDE :error=13, 权限被拒绝

python - 从Python子线程接收数据的简单方法

c++ - 有没有办法_get_UnhandledExceptionFilter?

java - 仅包含图像的 ListView

java - 这种形式的内存管理在 Java 中是否有意义?

java - 以通用功能接口(interface)作为参数的模拟方法 - Mockito

swift - 如何获取 "item"或已编辑的 NSOutlineView 文本字段单元格的行索引?

java - 更改 JFrame 标题

mysql - Rails - 库未加载 : @@HOMEBREW_PREFIX@@/opt/openssl/lib/libssl. 1.0.0.dylib (LoadError)

java - ThreadPoolExecutor中如何实现提交方法吞下异常,但执行-不