kerberos客户端使用报错

错误现象

报错信息如下,关键是:
“Cannot find any provider supporting AES/CBC/NoPadding”

Caused by: KrbException: Cannot find any provider supporting AES/CBC/NoPadding
    at sun.security.krb5.internal.crypto.Aes128CtsHmacSha1EType.decrypt(Aes128CtsHmacSha1EType.java:102)
    at sun.security.krb5.internal.crypto.Aes128CtsHmacSha1EType.decrypt(Aes128CtsHmacSha1EType.java:94)
    at sun.security.krb5.EncryptedData.decrypt(EncryptedData.java:175)
    at sun.security.krb5.KrbAsRep.decrypt(KrbAsRep.java:149)
    at sun.security.krb5.KrbAsRep.decryptUsingKeyTab(KrbAsRep.java:121)
    at sun.security.krb5.KrbAsReqBuilder.resolve(KrbAsReqBuilder.java:285)
    at sun.security.krb5.KrbAsReqBuilder.action(KrbAsReqBuilder.java:361)

分析了下,我们首先验证了在集群本身上用这个principal登录是正常的.

登录测试

1、kerberos登陆

kinit -k -t xxx.keytab username

2、hadoop命令验证

hadoop dfs -ls

应用配置信息检查

coresitePath= core-site.xml
hdfssitePath= hdfs-site.xml
principal=jiakuan
keytab=jiakuan.keytab
krb5ConfFile=krb5.conf
该有的都有了。

库的检查

又根据同事的建议,添加了两个jar,具体下载地址为jar下载地址
jar的名字为:local_policy.jar 和US_export_policy.jar
是JCE的两个jar包,设置好后仍然有问题。

问题原因

最终找到的是因为我们一个选项造成的:-Djava.ext.dirs=
我们覆盖了这个选项,导致一些java的功能无法使用。
写上同事的当时的总结:

kerberos客户端使用报错_第1张图片
image.png

你可能感兴趣的:(kerberos客户端使用报错)