kerberos GSS initiate failed认证失败的原因及解决方案


问题背景


GSS initiate failed: No valid credentials provided Failed to find any kerberos tgt

当同一OS用户并发执行多个认证脚本时,可能会遇到认证失败的问题,表现为GSS Initiate Failed等错误

问题原因


在典型的任务调度场景中,多个任务可能被同一用户同时调度执行。这就导致同一任务可能会并发执行kinit操作,而 kerberos Ticket Cache文件存储在/tmp目录下,文件名为krb5cc_{uid},其中uid为用户标识号。
因为同一OS用户下的多个脚本共享相同的uid,由于并发kinit操作,不同的认证会覆盖同一个uid下的Ticket Cache文件,导致Kerberos认证信息串掉。后续任务使用覆盖的Cache文件,导致认证失败。

解决方案


指定独立的Ticket Cache文件:
通过在Shell脚本中设置`KRB5CCNAME`环境变量,通过指定`KRB5CCNAME`环境变量为每个Kerberos用户指定独立的Ticket Cache文件,解决并发执行脚本时Ticket Cache文件被覆盖的问题。

export KRB5CCNAME=/tmp/xxx_krb5c
kinit -kt /path/xxx/keytab user_name

拓展


  1. 使用唯一标识生成文件名: 在生成Ticket Cache文件名时,考虑使用唯一标识,如进程ID(PID),以确保每个脚本生成的文件名是唯一的,避免文件覆盖问题。
  2. 动态生成配置文件: 在脚本中动态生成Kerberos配置文件,通过设置KRB5_CONFIG环境变量,指定不同的配置文件路径,以避免多个脚本之间的配置信息冲突。
  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值