0

0

Linux 安全:如何使用 Kerberos 实现集中认证 (KDC + 客户端)

舞夢輝影

舞夢輝影

发布时间:2025-11-20 23:53:02

|

693人浏览过

|

来源于php中文网

原创

答案:搭建Kerberos KDC需安装服务组件、配置krb5.conf、初始化数据库并启动服务,创建管理员主体及权限,为客户端生成密钥表;客户端安装工具、同步时间、复制配置文件并测试票据获取,结合PAM实现SSH等服务的集中认证,确保网络、防火墙与DNS一致。

linux 安全:如何使用 kerberos 实现集中认证 (kdc + 客户端)

在企业级 Linux 环境中,集中认证是保障系统安全的关键环节。Kerberos 作为一种成熟、安全的网络认证协议,通过密钥加密技术实现双向身份验证,有效防止密码在网络中明文传输。使用 Kerberos 可构建一个可信的集中式认证中心(KDC),为多台服务器和客户端提供统一的身份管理。下面介绍如何搭建 Kerberos KDC 服务并配置客户端接入。

部署 Kerberos 认证服务器(KDC)

Kerberos 的核心是密钥分发中心(Key Distribution Center, KDC),它包含认证服务器(AS)、票据授予服务器(TGS)以及数据库存储主体密钥。

以 CentOS/RHEL 系统为例:

  • 安装 Kerberos 服务组件:
    yum install krb5-server krb5-libs krb5-auth-dialog
  • 主要配置文件位于 /var/kerberos/krb5kdc/kdc.conf/etc/krb5.conf
  • 编辑 /etc/krb5.conf,设置域名与 KDC 信息:
[libdefaults]
  default_realm = EXAMPLE.COM
  dns_lookup_realm = false
  dns_lookup_kdc = false
  ticket_lifetime = 24h
  renew_lifetime = 7d
  forwardable = true

[realms]
  EXAMPLE.COM = {
    kdc = kdc.example.com
    admin_server = kdc.example.com
  }

[domain_realm]
  .example.com = EXAMPLE.COM
  example.com = EXAMPLE.COM
  • 初始化 Kerberos 数据库:
    kdb5_util create -s
    该命令会创建默认管理员用户和数据库,-s 表示生成 stash 文件用于开机自动解密数据库。
  • 启动并启用服务:
    systemctl enable krb5kdc kadmin
    systemctl start krb5kdc kadmin
  • 添加管理员权限主体:
    kadmin.local 进入管理界面,执行:
    addprinc admin/admin@EXAMPLE.COM
    并赋予其*/admin@EXAMPLE.COM 的权限(编辑 /var/kerberos/krb5kdc/kadm5.acl):
admin/admin@EXAMPLE.COM *
*

创建服务主体并导出密钥表

每台需要参与认证的服务(如 SSH、NFS)都必须在 KDC 中注册对应的服务主体(service principal)。

快剪辑
快剪辑

国内⼀体化视频⽣产平台

下载
  • 进入 kadmin 管理工具
    kadmin.local
  • 为某台主机创建 host 主体:
    addprinc -randkey host/client1.example.com@EXAMPLE.COM
  • 生成密钥表(keytab)文件并下载到对应客户端:
    ktadd -k /tmp/host.client1.keytab host/client1.example.com@EXAMPLE.COM
  • 将 keytab 文件安全复制到目标主机的 /etc/krb5.keytab,并设置权限:
    chmod 600 /etc/krb5.keytab
    chown root:root /etc/krb5.keytab

配置客户端接入 Kerberos 认证

客户端需安装必要的软件包并正确配置,才能向 KDC 请求票据。

  • 安装客户端工具:
    yum install krb5-workstation pam_krb5
  • 同步时间:确保所有机器时间一致(误差通常不超过 5 分钟),建议部署 NTP 服务。
  • 复制服务器端的 /etc/krb5.conf 到客户端,保证域和 KDC 配置一致。
  • 测试连接:
    kinit user@EXAMPLE.COM
    输入密码后使用 klist 查看是否成功获取 TGT 票据。
  • 若已配置 host keytab,可实现免密登录(如 SSH):
    在 sshd_config 中启用 GSSAPI:
    GSSAPIAuthentication yes
    GSSAPICleanupCredentials yes
    并在客户端 ssh 配置中打开 GSSAPIAuthenticatio

集成 PAM 实现登录认证

通过 PAM 模块,可让本地或远程登录(如 SSH)使用 Kerberos 身份验证。

  • 运行 authconfig-tui 或手动编辑 /etc/pam.d/system-auth。
  • 在 auth 和 account 类型中加入 kerberos 支持:
auth sufficient pam_krb5.so
account [default=bad success=ok user_unknown=ignore] pam_krb5.so
  • 注意:首次登录时若用户主目录不存在,可通过 autofs 或配置 pam_mkhomedir.so 自动创建。

基本上就这些。只要 KDC 稳定运行、时间同步准确、密钥表保护得当,Kerberos 就能为企业环境提供可靠的身份认证基础。不复杂但容易忽略的是网络延迟、防火墙规则(需开放 UDP 88 和 749 端口)以及 DNS 解析一致性。

相关专题

更多
default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.12.07

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

345

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2074

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

347

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

410

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

393

2023.10.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

3

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号