安装 kafka 连接器时出现 ConfluenceHubClient 异常

zil*_*anu 8 apache-kafka-connect mongodb-kafka-connector confluent-platform

我已经设置了 Kafka 集群并安装confluent-hubEC2实例上。我已经下载了confluent-hubtar 文件,解压并将二进制文件放入/usr/local/bin.

当我现在尝试安装任何连接器时,我收到 ClassNotFoundException。

[ec2-user@ip-172-31-88-110 bin]$ confluent-hub install confluentinc/kafka-connect-jdb c:latest --component-dir /opt/connectors --worker-configs /etc/kafka/connect.properties

/usr/local/bin/confluent-hub: line 13: cd: /usr/local/bin/../share/java: No such file or directory
Error: Could not find or load main class io.confluent.connect.hub.cli.ConfluentHubClient
Caused by: java.lang.ClassNotFoundException: io.confluent.connect.hub.cli.ConfluentHubClient
Run Code Online (Sandbox Code Playgroud)

我哪里出错了?

Fre*_*red 27

操作系统:macOS 12.4

我遇到了类似的错误:/opt/homebrew/bin/confluent-hub: line 13: cd: /opt/homebrew/bin/../share/java: No such file or directory Error: Could not find or load main class io.confluent.connect.hub.cli.ConfluentHubClient

我可以看到/opt/homebrew/bin/confluent-hub具有到 的符号链接/opt/homebrew/Caskroom/confluent-hub-client/7.1.1/bin/confluent-hub。然后我查看了文件中的代码/opt/homebrew/Caskroom/confluent-hub-client/7.1.1/bin/confluent-hub

#!/usr/bin/env bash

# (Copyright) [2018 - 2018] Confluent, Inc.

base_dir=$(dirname $0)

if [ -L /usr/local/bin/confluent-hub ]; then <<= line 9: I don't have this file and it should be a symbolic link to /opt/homebrew/Caskroom/confluent-hub-client/7.1.1/bin/confluent-hub
    #brew cask installation
    base_dir=$(dirname $( ls -l /usr/local/bin/confluent-hub | awk '{print $11}' ))
    #base_dir refers to Caskrooom/confluent-hub-client
fi
#cd -P deals with symlink from /bin to /usr/bin
java_base_dir=$( cd -P "$base_dir/../share/java" && pwd ) <<= line 13: where error thrown
HUB_CLI_CLASSPATH="${HUB_CLI_CLASSPATH}:${java_base_dir}/confluent-hub-client/*"
BIN_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"

exec java -cp "${HUB_CLI_CLASSPATH}" -Dbin.abs.path="${BIN_DIR}" io.confluent.connect.hub.cli.ConfluentHubClient "$@"
Run Code Online (Sandbox Code Playgroud)

由于第 9 行没有这样的文件/符号链接,因此代码直接跳转到第 13 行并开始抱怨找不到 java 二进制文件。如果不进入 if 语句,当前 $base_dir =/opt/homebrew/bin并且没有/opt/hombrew/share/java文件。

实际上java文件位于/opt/homebrew/Caskroom/confluent-hub-client/7.1.1/share/java/. 我们必须让代码进入 if 语句内部,以便 $base_dir 可以被覆盖以使用正确的路径/opt/homebrew/Caskroom/confluent-hub-client/7.1.1/bin

为了确保代码在 if else 语句内部执行,我手动创建了一个符号链接:sudo ln -s /opt/homebrew/Caskroom/confluent-hub-client/<CONFLUENT-HUB-VERSION>/bin/confluent-hub /usr/local/bin/confluent-hub。然后问题就解决了。

  • 谢谢你!但为什么会出现这个问题呢?这对汇合负责吗? (2认同)
  • 谢谢你,你也救了我: `sudo ln -s /opt/homebrew/Caskroom/confluence-hub-client/7.1.2/bin/confluence-hub /usr/local/bin/` (2认同)

zil*_*anu 0

该二进制文件存在于/usr/bin. 我从该位置删除了该文件,它开始工作。