kafka学习

今天在写kafka的demo的时候遇到了一个很奇怪的问题。贴出报错

[2017-08-30 16:05:31,213] ERROR Closing socket for 127.0.0.1:9092-127.0.0.1:54794 because of error (kafka.network.Processor)
kafka.network.InvalidRequestException: Error getting request for apiKey: 3 and apiVersion: 2
    at kafka.network.RequestChannel$Request.liftedTree2$1(RequestChannel.scala:95)
    at kafka.network.RequestChannel$Request.<init>(RequestChannel.scala:87)
    at kafka.network.Processor$$anonfun$processCompletedReceives$1.apply(SocketServer.scala:488)
	at kafka.network.Processor$$anonfun$processCompletedReceives$1.apply(SocketServer.scala:483)
    at scala.collection.Iterator$class.foreach(Iterator.scala:893)
    at scala.collection.AbstractIterator.foreach(Iterator.scala:1336)
    at scala.collection.IterableLike$class.foreach(IterableLike.scala:72)
    at scala.collection.AbstractIterable.foreach(Iterable.scala:54)
    at kafka.network.Processor.processCompletedReceives(SocketServer.scala:483)
    at kafka.network.Processor.run(SocketServer.scala:413)
    at java.lang.Thread.run(Thread.java:744)
Caused by: java.lang.IllegalArgumentException: Invalid version for API key 3: 2
    at org.apache.kafka.common.protocol.ProtoUtils.schemaFor(ProtoUtils.java:31)
    at org.apache.kafka.common.protocol.ProtoUtils.requestSchema(ProtoUtils.java:44)
    at org.apache.kafka.common.protocol.ProtoUtils.parseRequest(ProtoUtils.java:60)
    at org.apache.kafka.common.requests.MetadataRequest.parse(MetadataRequest.java:96)
    at org.apache.kafka.common.requests.AbstractRequest.getRequest(AbstractRequest.java:48)
    at kafka.network.RequestChannel$Request.liftedTree2$1(RequestChannel.scala:92)
    ... 10 more

再把自己的代码和配置文件检查了一遍又一遍的时候,发现没有问题,但是问题出现在哪里呢?为什么会报错呢?于是把报错全部拿出来仔细看看,java.lang.IllegalArgumentException: Invalid version for API key 3: 2,猜到了可能是kafka的jar包版本不对。果断从kafka-clients-0.10.1.0.jar换成kafka-clients-0.10.2.0.jar。问题完美解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值