Kafaka使用者init抛出异常:无法找到'KafkaClient'条目

时间:2016-03-24 00:29:59

标签: ibm-cloud message-hub

我有java类实现Runnable并在bluemix中实例化kafka使用者。尝试实例化KafkaConsumer时,此类将抛出异常。 jaas.conf文件存储在共享目录中。这在过去的一个月里运作良好。它今天开始抛出这个错误。我不记得对我的代码进行任何更改。我正在使用kafka-client 0.9.0.0。我也尝试使用kafka客户端0.9.0.1,结果相同。

org.apache.kafka.common.KafkaException: 
java.lang.IllegalArgumentException: Could not find a 
'KafkaClient' entry in `/home/vcap/app/wlp/usr/shared/config/lib
 /global/jaas.conf`. 

文件jaas.conf出现在它正在寻找的位置 其中包含以下内容。

KafkaClient {
  com.ibm.messagehub.login.MessageHubLoginModule required
  serviceName="kafka"
  username="xxxxxxx"
  password="xxxxxxx"
};

1 个答案:

答案 0 :(得分:4)

基于“jass.conf”文件的路径,我假设您在Bluemix中运行Liberty应用程序,如果是这种情况,那么您必须确保将jaasLoginModule指定到server.xml中,如下所示:

<featureManager>
   <feature>appSecurity-2.0</feature>
</featureManager>

<library id="messageHubLoginLib">
  <fileset dir="${server.config.dir}" includes="messagehub.login-1.0.0.jar"/>
</library>

<jaasLoginModule id="KafkaClient"
            className="com.ibm.messagehub.login.MessageHubLoginModule"
            controlFlag="REQUIRED" libraryRef="messageHubLoginLib">
   <options serviceName="kafka" username="#USERNAME" password="#PASSWORD"/>
</jaasLoginModule>

<jaasLoginContextEntry id="KafkaClient" name="KafkaClient" loginModuleRef="KafkaClient"  />

注意:仅为了澄清,如果您在Bluemix中使用Liberty应用程序,那么当前的JAAS配置不使用该jaas.conf文件。因此必须使用如上所述的server.xml配置。

这是一个link,您可以在其中找到有关如何配置Liberty

的更多信息