1

我已经阅读了很多(如果不是所有的话)关于 Web 请求超时的帖子,并且提供的解决方案没有奏效。我从 Big Commerce 获得订单,然后更新 Big Commerce 状态代码。我可以更新 2 个订单,然后我在第三个时超时,无论是星期几还是一天中的时间,每次都超时。

App.Config 文件有:

```
<system.web>
    <httpRuntime executionTimeout="180" />
</system.web>
```

代码:

```
    Try
        Dim strJSON As String = "{""status_id"": 9}"
        Dim postBytes As Byte() = System.Text.Encoding.UTF8.GetBytes(strJSON)
        For i As Integer = 0 To dto.Rows.Count - 1
            strWebOrder = dto.Rows(i).Item("WebOrder")
            Dim strHttp As String = "https://api.bigcommerce.com/stores/storeid/v2/orders/" & strWebOrder
            Dim request As HttpWebRequest = DirectCast(WebRequest.Create(strHttp), HttpWebRequest)
            request.Accept = "application/json"
            request.ContentType = "application/json"
            request.Headers("X-Auth-Token") = strAuthToken
            request.Timeout = 10000
            request.AllowWriteStreamBuffering = False
            request.SendChunked = True
            request.Method = "PUT"
            Dim postStream As Stream = request.GetRequestStream()
            postStream.Write(postBytes, 0, postBytes.Length)
            Dim response As HttpWebResponse = DirectCast(request.GetResponse(), HttpWebResponse)
            If response.StatusCode = 200 Then
                strErrorRef = "Web " & strWebOrder
                strErrorReason = "Order Status Changed to Exported"
                strPutMessage = ""
                WriteError()
            Else
                strErrorRef = "Web " & strWebOrder
                strErrorReason = "Unable to change Web Order Status to Exported"
                strPutMessage = ""
                WriteError()
            End If
        Next
    Catch ex As Exception
        strErrorRef = "Web " & strWebOrder
        strErrorReason = "Unable to change Web Order Status to Exported"
        strPutMessage = (ex.ToString)
        WriteError()
    End Try
```
4

1 回答 1

0

您是否尝试过增加 executionTimeout 属性中的秒数?如果将其增加到 300,这将使您的应用程序在关闭之前有 5 分钟执行命令,而不是您当前使用的 3 分钟。

我不确定您尝试或阅读的所有内容,但听起来您拥有的代码至少需要 2-3 分钟才能完成 2 个订单,这就是为什么您看到的结果是相同的,无论它正在执行的时间。

您是否尝试过重构代码以将其分解一下,例如:在一个函数中获取所有 status_id 为 9 的订单,或者将这些 order_id 存储在另一个函数的数组中,然后在一个新函数中循环通过存储的数组进行更新status_id?

另外,您是否在使用 webhook?

于 2021-01-04T15:18:54.803 回答