Linux pod 使用 keytab 对 MS-SQL Windows 服务器进行身份验证

Linux pod 使用 keytab 对 MS-SQL Windows 服务器进行身份验证

无法使 Kerberos 身份验证从 Linux 运行到 Windows 上的 MS-SQL 服务器。在 AD 中添加了新用户。

New-ADUser -Name "user" -GivenName "user" -SamAccountName "user" -UserPrincipalName "[email protected]"  –AccountPassword (ConvertTo-SecureString "password" -AsPlainText -force) -Enabled $true

生成的 keytab 文件。

ktpass -out krb5.keytab -mapUser [email protected] -pass password  -crypto AES256-SHA1 -ptype KRB5_NT_PRINCIPAL -princ MSSQLSvc/sql.my.domain:[email protected]

在 Linux 服务器中添加了 krb5.conf 的配置

[logging]
 default = FILE:/var/log/krb5libs.log
 kdc = FILE:/var/log/krb5kdc.log
 admin_server = FILE:/var/log/kadmind.log

[libdefaults]
 dns_lookup_realm = false
 ticket_lifetime = 24h
 renew_lifetime = 7d
 forwardable = true
 rdns = false
 pkinit_anchors = /etc/pki/tls/certs/ca-bundle.crt
 default_ccache_name = KEYRING:persistent:%{uid}

 default_realm = MY.DOMAIN
[realms]

 MY.DOMAIN = {
 }

[domain_realm]
 my.domain = MY.DOMAIN
 .my.domain = MY.DOMAIN

将 keytab 复制到 linux 服务

完成 kinit

kinit -k  MSSQLSvc/sql.my.domain:[email protected]

klist节目

klist
Ticket cache: FILE:/etc/krb/cache
Default principal: MSSQLSvc/sql.my.domain:[email protected]

Valid starting     Expires            Service principal
05/27/21 07:24:27  05/27/21 17:24:27  krbtgt/[email protected]
    renew until 06/03/21 07:24:27

和失败……

/opt/mssql-tools/bin/sqlcmd -S sql.my.domain
Sqlcmd: Error: Microsoft ODBC Driver 17 for SQL Server : SSPI Provider: Message stream modified.
Sqlcmd: Error: Microsoft ODBC Driver 17 for SQL Server : Cannot generate SSPI context.

答案1

问题出在 Active Directory 端的 SPN 记录中。Microsoft SQL Kerberos 工具帮了大忙。如果 SQL 服务器上的 kerberos 工具未启动,请尝试从 SQL 服务器上的本地管理员中删除您的 AD 用户。

https://docs.microsoft.com/en-us/troubleshoot/sql/connect/kerberos-configuration-manager-available

相关内容