Invoke-RestMethod 挂在长 运行 端点上

Invoke-RestMethod hangs on long running endpoints

我们在 PowerShell 脚本中使用 Invoke-RestMethod 来调用具有可变长度运行时的 GET 方法端点。有些呼叫可能会在几秒钟后 return,有些可能最多需要 20 分钟。我们通过 -TimeoutSec 参数为调用设置了 50 分钟超时。

只需要几秒钟的调用 return 很好并输出预期的响应。较长的调用(例如 5 分钟)永远不会 return 并且 Invoke-RestMethod 命令用完了整个 50 分钟的超时,尽管我们在 Web 服务器日志上确认服务器已经很久 return编辑了 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 结束那些长 运行 调用。