gpt4 book ai didi

powershell - 10 小时后长时间运行的 Exchange powershell 脚本中的 Kerberos 错误

转载 作者:行者123 更新时间:2023-12-01 03:12:18 29 4
gpt4 key购买 nike

我实现了一个 powershell 脚本,它将 Exchange 设置分配给我们的用户邮箱 (Exchange 2016)。由于我们有很多邮箱并且分配设置很慢,脚本将运行超过 15 个小时。但是大约 10 小时后,我收到以下错误:

Processing data for a remote command failed with the following error message: Error occurred during the Kerberos response. 
[Server=XXXXX, TimeStamp = 74/2018 01:25:49]
For more information, see the about_Remote_Troubleshooting Help topic.
At C:\Users\ACCOUNT\AppData\Local\Temp\tmp_cj3akhk4.osq\tmp_cj3akhk4.osq.psm1:77943 char:9
+ $steppablePipeline.End()
+ ~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : OperationStopped: (XXXX:String) [], PSRemotingTransportException
+ FullyQualifiedErrorId : JobFailure
+ PSComputerName : XXXX

我的脚本退出操作,并在两次重试(失败)后显示身份验证提示。在那里我可以输入服务帐户的密码,脚本继续运行。但是,仅当我在 PS 命令提示符下运行脚本时,此对话框才可见。如果脚本作为 Windows 任务启动,它只是挂起并且不会继续。

使用以下代码打开并导入到 Exchange 的连接。该代码可以根据传递的参数连接到我们的本地 Exchange 或在线 Exchange。该问题目前仅在连接到我们的本地(本地)Exchange 基础架构时才会发生。
Function Connect-Exchange{
PARAM(
[parameter(Mandatory=$false)]
[String]$TargetExchange = 'Local'
)
BEGIN{}
PROCESS{
if ($ExchangeSessionInfo.Session -and $ExchangeSessionInfo.Type -eq $TargetExchange -and $ExchangeSessionInfo.Session.State -eq 'Opened'){
# Nothing to do, we are already connected.
Write-Log "Exchange connection type $($TargetExchange) already established, nothing to do."
} else {
if ($ExchangeSessionInfo.Session -and $ExchangeSessionInfo.Type -ne $TargetExchange -and $ExchangeSessionInfo.Session.State -eq 'Opened'){
# We have a open session with the wrong type. We close it.
Remove-PSSession $ExchangeSessionInfo.Session
$ExchangeSessionInfo.Session = $null
$ExchangeSessionInfo.Status = 'undefined'
$ExchangeSessionInfo.Type = ''
}
# We close all other existing Exchange sessions we created.
get-pssession -Name "Exchange" -ErrorAction SilentlyContinue | remove-pssession

# Now connect to the requestes Exchange infrastructure and import session.
$Connected = $False
$RetryCount = 5
do{
try {
If ($TargetExchange -eq 'Local'){
$ExchangeServer = Get-Random -InputObject $LocalExchangeConfig.ExchangeServers
$ExchangeSessionInfo.Session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri "http://$($ExchangeServer)/PowerShell/" -Credential $EOCredentials -Authentication Kerberos -Name "Exchange"
} else {
$ExchangeSessionInfo.Session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri 'https://ps.protection.outlook.com/powershell-liveid/' -Credential $EOCredentials -Authentication Basic -AllowRedirection -Name "Exchange"
}
$Res = Import-PSSession $ExchangeSessionInfo.Session -WarningAction SilentlyContinue -AllowClobber

# Store Exchange status in session variable.
$Connected = $True
$ExchangeSessionInfo.Status = 'connected'
$ExchangeSessionInfo.Type = $TargetExchange
} catch {
$err = Write-Error -err $error -msg "Could not connect to Exchange server type '$($TargetExchange)' (Retries left: $($RetryCount))." -Break $false
get-pssession -Name "Exchange" -ErrorAction SilentlyContinue | remove-pssession
$RetryCount -= 1
}
} while (!$Connected -and ($RetryCount -gt 0))

# If we do not have connection here, this is an error.
if (!$Connected) {
$ExchangeSessionInfo.Session = $null
$ExchangeSessionInfo.Status = 'undefined'
$ExchangeSessionInfo.Type = ''
throw "No connection to Exchange server (type: $($TargetExchange)) could be established."
} else {
# Get list of available mailbox DBs including mailbox count and create hashtable to store statistics. We only have to get it the first time.
if (($MailboxDBList.count -eq 0) -and ($TargetExchange -eq 'Local')){
Write-Log "Getting current Exchange DB configuration and mailbox count. Takes a moment."
$MailboxDBList = Get-MailboxDBCount -Type $LocalExchangeConfig.DistributeMailboxes
}
}
}
}
END{
return $ExchangeSessionInfo
}
}

以下代码应用了一组预定义的 Exchange 设置:
...                 
$TryCount = 0
$Done = $false
do{
# It takes a while after enabling mailbox until settings can be applied. So we need to retry.
try{
# If we need to execute a setting several times.
if ($MailboxSetting.LoopOver){
# We have a loop value (array).
foreach ($LoopValue in $MailboxSetting.LoopOver){
# Copy parameter as we have to change a value (loop value).
$TempParams = $Params.PsObject.Copy()
@($Params.getenumerator()) |? {$_.Value -match '#LOOPVALUE#'} |% {$TempParams[$_.Key]=$LoopValue}
$res = & $MailboxSetting.Command -ErrorAction Stop @TempParams -WhatIf:$RunConfig.TestMode
}
} else {
# THE PROBLEM HAPPENS HERE
$res = & $MailboxSetting.Command -ErrorAction Stop @Params -WhatIf:$RunConfig.TestMode
}
# Write-Log "Setting command $($MailboxSetting.Command) executed successfully"
$Done = $true
} catch{
$tryCount++
$res = Write-Error -err $error -msg "Error applying mailbox settings, account: $($AccountDetails.sAMAccountName), retry count: $($TryCount)" -Break $false
Start-Sleep -s $(($Retires-$TryCount) * 5)
}
} while ((!$done) -and ($tryCount -lt $Retires))
...

我确信该错误与代码无关,因为脚本可以正常运行数小时并应用所有设置。但是,大约 10 小时后,Kerberos 票证似乎已过期,然后脚本无法再访问 Exchange,而无需重新登录。

有没有办法防止 Kerberos 票证过期或续订?

任何帮助,将不胜感激。

最佳答案

我认为您遇到了域安全策略(组策略对象 - GPO)=> security settings/account policy/Kerberos policy 限制。

您的两个有效选项是:
Maximum lifetime for user ticket => 默认值为 10 小时
Maximum lifetime for user ticket renewal => 默认值为 7 天(这是可以续订机票的期限)。

  • 有没有办法防止 Kerberos 票证过期或续订?

  • 对于第一个问题,您“只需要”将 maximum lifetime for user ticket 设置调整为您认为合适的值。

    第二个更棘手。我只想通过 powershell 清除所有 kerberos 票证。更多信息 - viewing and purging cached kerberos tickets 这会给你一个新的。

    如果票可以续签,您必须检查 RENEABLE flag - 您可以通过 kinit 查看。也许 kinit -R 可能足以续订票证。 (我自己没有这样做)您也可以通过 kerberos for windows 更新它

    编辑 -- 添加 klist purge 以清除所有 Kerberos 票证,以便可以续订。

    由于您有 klist ,因此您可以清除所有票证,必须在提升的 powershell 提示符下运行
    (全部归功于 JaredPoeppelman ):
    Get-WmiObject Win32_LogonSession | Where-Object {$_.AuthenticationPackage -ne 'NTLM'} | ForEach-Object {klist.exe purge -li ([Convert]::ToString($_.LogonId, 16))}  

    然后检查您的 TGT 是否通过以下方式更新:
    klist tgt
    注意: 你必须在任何地方使用 FQDN 名称!

    关于powershell - 10 小时后长时间运行的 Exchange powershell 脚本中的 Kerberos 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51168045/

    29 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com