我有一个三节点群集,上面同时安装了Kerberos和Ranger。

对于作为普通用户(tom)使用的一个用例,我有点困惑。我的/ home / tom中有hdfs.headless.keytabhbase.headless.keytab文件,因此我可以使用

[tom@master keytabs]$ ls /home/tom -l
total 8
-r--r----- 1 tom tom 373 Oct 26 02:32 hbase.headless.keytab
-r--r----- 1 tom tom 368 Nov  8 18:59 hdfs.headless.keytab

因此,如果我要写入HDFS,则始终可以通过上述文件来启动Kerberos票证:
[tom@master root]$ klist
klist: No credentials cache found (ticket cache FILE:/tmp/krb5cc_500)
[tom@master keytabs]$ kinit -kt /home/tom/hdfs.headless.keytab [email protected]
[tom@master keytabs]$ klist
Ticket cache: FILE:/tmp/krb5cc_500
Default principal: [email protected]

Valid starting     Expires            Service principal
11/08/18 19:12:10  11/09/18 19:12:10  krbtgt/[email protected]
        renew until 11/08/18 19:12:10

现在,我要激活HBase的票证:
[tom@master keytabs]$ kinit -kt /home/tom/hbase.headless.keytab [email protected]
[tom@master keytabs]$ klist
Ticket cache: FILE:/tmp/krb5cc_500
Default principal: [email protected]

Valid starting     Expires            Service principal
11/08/18 19:30:01  11/09/18 19:30:01  krbtgt/[email protected]
        renew until 11/08/18 19:30:01

现在,当我运行以下命令(写入HDFS)时,我得到:
[tom@master keytabs]$ hdfs dfs -mkdir /tom
mkdir: Permission denied: user=hbase, access=WRITE, inode="/tom":hdfs:hdfs:drwxr-xr-x

我不确定为什么在写HDFS时先在HBase之前为HDFS购票并为Tom买票时为什么不能做上述事情,但现在我将其视为HBase用户并且不会让我写HDFS ..我无法使用hdfs,因为我不知道密码。.有人可以解释我如何设置一个名为tom的主体同时执行HBase和HDFS票证操作吗?

最佳答案

AFAIK更好的方法是创建一个名为“tom.headless.keytab”的密钥标签,并创建一个名为“tom @ bozxxx”的密钥
我假设Ranger上已经存在用户tom,如果没有,您可以同步用户(基于Ranger的配置方式,是否配置为从文件读取还是从Unix用户或Ldap读取),或者只是创建了快捷方式用户从Ranger UI中获取“tom”。一旦创建了用户,就可以在HDFS和HBASE上访问tom用户。然后执行Kinit然后您可以运行命令

关于hadoop - 游侠和Kerberos,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53204984/

10-16 12:47