Invoke-RestMethod 挂在长时间运行的端点上

问题描述

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...