zil*_*anu 8 apache-kafka-connect mongodb-kafka-connector confluent-platform
我已经设置了 Kafka 集群并安装confluent-hub
在EC2
实例上。我已经下载了confluent-hub
tar 文件,解压并将二进制文件放入/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
。然后问题就解决了。
归档时间: |
|
查看次数: |
2966 次 |
最近记录: |