重试请求以 "Content length mismatch" 结束



我的问题是这样的:

我有一个 Azure API,我创建了一个 API 并添加了后端重试策略,如下所示。

<backend>
    <retry condition="@("{{Transient-ErrorCode}}".Contains(Convert.ToString(context.Response.StatusCode)))" count="3" interval="5" first-fast-retry="false">
        <forward-request />
    </retry>
</backend>

服务器第一次返回成功(状态代码:200(,当它启动重试时,它遇到了以下情况(我也在成功时重试,因为测试重试工作正常。

forward-request (1.326 ms)
{
"messages": [
    "Content length mismatch",
    "Content length mismatch"
    ]
}

请帮助您的想法/经验。

这是因为客户端发送的请求在 APIM 中默认不会缓存在内存中,而是直接从客户端流式传输到后端。因此,当需要重试请求时,请求有效负载不存在。我假设您只对有正文的请求有问题。

要解决此问题,您首先需要缓存请求正文:

<inbound>
    <set-variable name="body" value="@(context.Request.Body.As<string>(preserveContent: true))" />
</inbound>
<backend>
    <retry condition="@("{{Transient-ErrorCode}}".Contains(Convert.ToString(context.Response.StatusCode)))" count="3" interval="5" first-fast-retry="false">
        <set-body>@((string)context.Variables["body"])</set-body>
        <forward-request />
    </retry>
</backend>

通过使用forward-request策略上的属性buffer-request-body来包含正文似乎还有另一种简化:

<!-- no need to put body into variable in the inbound policy -->
<backend>
    <retry condition="@("{{Transient-ErrorCode}}".Contains(Convert.ToString(context.Response.StatusCode)))" count="3" interval="5" first-fast-retry="false">
        <!-- no need for the set-body policy -->
        <forward-request buffer-request-body="true" />
    </retry>
</backend>

有关转发请求的属性,请参阅 doco

相关内容

最新更新