【kerberos】Kerberos 调试

增加详细程度

默认情况下,kinit 不显示任何调试信息,并且通常会在失败时返回一个模糊的错误。以下命令将启用详细日志记录到标准输出,这有助于调试。

KRB5_TRACE=/dev/stdout kinit -V

例如:

KRB5_TRACE=/dev/stdout kinit -V -kt /opt/kafka.keytab kafka

Java Kerberos/KRB5 和 SPNEGO 调试系统属性

处理 Kerberos 的 Java 内部类具有启用调试日志记录的系统属性。这些属性支持大量调试,因此应仅在尝试诊断问题时打开,然后关闭。如有必要,它们也可以组合使用。

第一个属性处理 Kerberos 错误,并可帮助解决配置错误的 KDC 服务器、问题和其他问题。krb5.conf

-Dsun.security.krb5.debug=true

第二个属性专门用于对 Kerberos 安全 Web 端点进行 SPNEGO 调试。SPNEGO 可能难以调试,但此标志可以帮助启用其他调试日志记录。

-Dsun.security.spnego.debug=true

可以使用 Apache Hadoop 和相关组件的变量来设置这些属性,如下例所示:*_OPTS

HADOOP_OPTS="-Dsun.security.krb5.debug=true" #-Dsun.security.spnego.debug=true"

Hadoop 命令行调试日志记录

大多数Apache Hadoop命令行工具使用相同的底层机制进行日志记录。 不允许动态调整日志级别,但允许在使用命令之前调整记录器。Hadoop将根记录器公开为环境变量。这可用于在不更改 hdfs hadoop yarn Log4jLog4jHADOOP_ROOT_LOGGERlog4j.properties

HADOOP_ROOT_LOGGER=DEBUG,console hdfs ...

调试 Hadoop 用户和组

使用 Apache Hadoop 的用户通常通过 Kerberos 进行身份验证,如此处所述。身份验证后,用户的用户名将用于确定组。Apache Hadoop 的组可以通过多种方式使用 Hadoop 组映射进行配置。调试 Apache Hadoop 认为您的用户和组是什么对于正确设置安全性至关重要。

第一个命令采用用户主体,并将根据配置的hadoop.security.auth_to_local规则返回用户名。

hadoop org.apache.hadoop.security.HadoopKerberosName USER_PRINCIPAL
第二个命令采用用户名并确定与其关联的组。这将使用配置的 Hadoop 组映射来确定组是什么。

hdfs groups USERNAME

第三个命令是使用当前经过身份验证的用户并打印出当前用户的 UGI。它还可以使用主体和密钥表来打印有关该 UGI 的信息。

hadoop org.apache.hadoop.security.UserGroupInformation
hadoop org.apache.hadoop.security.UserGroupInformation "PRINCIPAL" "KEYTAB"

第四个命令 KDiag 相对较新,因为它是在 HADOOP-12426 中引入的,并在 Apache Hadoop 2.8.0 中首次发布。此命令将一些其他调试工具合并为一个,并检查常见的与 Kerberos 相关的错误配置。

# Might also set HADOOP_JAAS_DEBUG=true and set the log level 'org.apache.hadoop.security=DEBUG'
hadoop org.apache.hadoop.security.KDiag

结论
在处理 Kerberos 和分布式系统时,一半以上的工作是知道在哪里查找以及要生成哪些日志。使用正确的日志,可以调试问题并快速解决问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要启动Kerberos,您需要按照以下步骤进行操作: 1. 配置Kerberos服务器:首先,您需要在服务器上安装Kerberos软件包。根据您使用的操作系统,可以选择不同的软件包。在安装完成后,您需要进行一些配置,如设置Kerberos域和管理员凭证。 2. 创建Kerberos数据库:使用Kerberos提供的工具,您需要创建一个Kerberos数据库,其中包含了所有的用户和服务的凭证信息。这个数据库可以存在于文件中,也可以使用数据库服务器来存储。 3. 配置Kerberos客户端:在需要使用Kerberos认证的客户端上,您需要安装Kerberos客户端软件包,并进行相应的配置。这包括指定Kerberos服务器的地址和域信息。 4. 创建服务主体和密钥表:对于每个需要使用Kerberos认证的服务,您需要为其创建一个服务主体,并生成相应的密钥表。这些信息将用于服务的身份验证。 5. 配置应用程序和服务:在应用程序或服务中,您需要配置其使用Kerberos进行身份验证。这通常涉及修改配置文件或代码,以便使用正确的凭证进行认证。 6. 测试和调试:完成上述步骤后,您可以尝试使用Kerberos认证来测试您的配置是否正确。确保所有的服务和客户端都能够成功地进行身份验证和访问。 请注意,Kerberos是一个复杂的安全协议和系统,涉及到许多细节和配置选项。在部署和配置Kerberos时,建议参考相关的文档和指南,以确保正确性和安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值