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 结束那些长 运行 调用。
我们在 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 结束那些长 运行 调用。