我有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"
};
答案 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
的更多信息