连接器任务状态无法连接

时间:2018-08-27 09:08:56

标签: java apache-kafka apache-kafka-connect debezium

连接器的任务状态因错误而失败:

org.apache.kafka.connect.errors.ConnectException: java.lang.NoClassDefFoundError

我正在以分布式模式运行kafka connect集群,并且正在使用ambari部署的kafka(0.10.0.2.5)connect。

我使用导出CLASSPATH = /连接器/的路径给了debezium mysql连接器路径。

使用以下命令将连接器配置加载到Kafka Connect中:

curl -i -X POST -H "Accept:application/json" \ 
    -H  "Content-Type:application/json" http://localhost:8083/connectors/ \
    -d '{
      "name": "MYSQL_CONNECTOR",
      "config": {
            "connector.class": "io.debezium.connector.mysql.MySqlConnector",
            "database.hostname": "10.224.21.36",
            "database.port": "3306",
            "database.user": "root",
            "database.password": "shobhna",
            "database.server.id": "1",
            "database.server.name": "demo",
            "database.history.kafka.bootstrap.servers": "slnxhadoop04.noid.in:6669",
            "database.history.kafka.topic": "dbhistory.demo" ,
            "include.schema.changes": "true"
       }
    }'

现在检查连接器状态后,出现错误:

 - {"name":"MYSQL_CONNECTOR","connector":{"state":"RUNNING","worker_id":"172.26.177.115:8083"},
   "tasks":[{"state":"FAILED","trace":"org.apache.kafka.connect.errors.ConnectException:
   java.lang.NoClassDefFoundError:
   org/apache/kafka/clients/admin/AdminClient\n\tat
   io.debezium.connector.mysql.MySqlConnectorTask.start(MySqlConnectorTask.java:218)\n\tat
   io.debezium.connector.common.BaseSourceTask.start(BaseSourceTask.java:45)\n\tat
   org.apache.kafka.connect.runtime.WorkerSourceTask.execute(WorkerSourceTask.java:137)\n\tat
   org.apache.kafka.connect.runtime.WorkerTask.doRun(WorkerTask.java:140)\n\tat
   org.apache.kafka.connect.runtime.WorkerTask.run(WorkerTask.java:175)\n\tat
   java.util.concurrent.Executors$RunnableAdapter.cal(Executors.java:511)\n\tat
   java.util.concurrent.FutureTask.run(FutureTask.java:266)\n\tat
   java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)\n\tat
   java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)\n\tat
   java.lang.Thread.run(Thread.java:745)\nCaused by:
   java.lang.NoClassDefFoundError:
   org/apache/kafka/clients/admin/AdminClient\n\tat
   io.debezium.relational.history.KafkaDatabaseHistory.initializeStorage(KafkaDatabaseHistory.java:336)\n\tat
   io.debezium.connector.mysql.MySqlSchema.intializeHistoryStorage(MySqlSchema.java:260)\n\tat
   io.debezium.connector.mysql.MySqlTaskContext.initializeHistoryStorage(MySqlTaskContext.java:194)\n\tat
   io.debezium.connector.mysql.MySqlConnectorTask.start(MySqlConnectorTask.java:126)\n\t...
   9 more\nCaused by: java.lang.ClassNotFoundException:
   org.apache.kafka.clients.admin.AdminClient  \n\tat
   java.net.URLClassLoader.findClass(URLClassLoader.java:381)\n\tat
   java.lang.ClassLoader.loadClass(ClassLoader.java:424)\n\tat
   sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)\n\tat
   java.lang.ClassLoader.loadClass(ClassLoader.java:357)\n\t

1 个答案:

答案 0 :(得分:1)

找不到内置的Kafka类,而不是您的连接器

  

NoClassDefFoundError:      org / apache / kafka / clients / admin / AdminClient

...

  

我正在使用kafka(0.10.0.2.5)

确保您正在运行1)与您的Kafka代理匹配的Connect Server版本2)使用对该版本的Connect使用代码的连接器

例如,AdminClient仅存在于Kafka 0.11+中。

在最新的HDP发行版中,您将获得Kafka 1.1(不同于0.11),这是最新的Debezium构建并针对https://debezium.io/docs/releases/进行测试的版本。

Debezium需要AdminClient来制作和注册主题信息,因此我不确定它是否可以在旧版本(例如0.10)上使用

在Kafka Wiki中指出,较新版本的Connect 服务器可以与旧的代理进行通信,但是Connector类使用的协议尚待争论。