首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Accumulo kerberos认证

Accumulo kerberos认证
EN

Stack Overflow用户
提问于 2017-02-13 08:59:59
回答 1查看 306关注 0票数 1

我在使用Kerberos进行Accumulo身份验证时遇到了问题。当我尝试创建令牌时,我的应用程序异常失败:

代码语言:javascript
复制
Exception in thread "main" java.lang.IllegalArgumentException: Subject is not logged in via Kerberos
    at com.google.common.base.Preconditions.checkArgument(Preconditions.java:92)
    at org.apache.accumulo.core.client.security.tokens.KerberosToken.<init>(KerberosToken.java:56)

我的连接代码:

代码语言:javascript
复制
UserGroupInformation.loginUserFromKeytab("user", "keytab"); // ok
KerberosToken token = new KerberosToken(); // Exception goes here

任何帮助都是非常感谢的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-02-13 21:14:48

似乎您的Kerberos登录没有像预期的那样正常工作。该构造函数正在执行以下操作:

代码语言:javascript
复制
  public KerberosToken(String principal) throws IOException {
    requireNonNull(principal);
    final UserGroupInformation ugi = UserGroupInformation.getCurrentUser();
    checkArgument(ugi.hasKerberosCredentials(), "Subject is not logged in via Kerberos");
    checkArgument(principal.equals(ugi.getUserName()), "Provided principal does not match currently logged-in user");
    this.principal = ugi.getUserName();
  }

不知何故,您的UGI调用导致当前用户没有Kerberos凭据。你应该能亲自检查这个。我没有一个简单的解决方案供您使用,但是您可以尝试使用以下方法来调试:

  1. 在org.apache.hadoop.security=DEBUG配置中设置log4j
  2. 将-Dsun.security.krb5.debug=true传递给JVM (或使用System.setProperty(.))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42200132

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档