问题描述
我们在 PowerShell 脚本中使用 Invoke-RestMethod
来调用具有可变长度运行时的 GET
方法端点。有些电话可能会在几秒钟后返回,有些可能需要长达 20 分钟。我们已通过 -TimeoutSec
参数设置了 50 分钟的通话超时时间。
只需几秒钟的调用即可正常返回并输出预期的响应。更长的调用(例如 5 分钟)永远不会返回,并且 Invoke-RestMethod
命令用完整个 50 分钟超时,尽管我们在网络服务器日志中确认服务器早已返回 200 OK
。
try
{
$Url = "https://example.com/task" # GET
$Timeout = 3000 # 50 minute timout
$Response = Invoke-RestMethod $Url -TimeoutSec $Timeout
Write-Host $Response
}
catch
{
Write-Host $_.Exception
}
端点上没有身份验证。 PowerShell 版本为 7。脚本在托管被调用的 Web 服务器的同一台机器上运行。
这是我们不知道的 Invoke-RestMethod
配置问题吗?我们使用基本相同的脚本处理 Invoke-WebRequest
时遇到了类似的问题。
解决方法
我们能够通过将 -DisableKeepAlive
开关添加到 Invoke-RestMethod
命令来解决此问题。似乎 HTTP 保持活动功能阻止了 PowerShell 结束那些长时间运行的调用。