首页 > 解决方案 > Cloud Run 请求触发错误 400 未到达已部署的服务

问题描述

我目前正在使用Google Cloud Run部署 API,尽管一切正常,但我现在很难理解我遇到的错误。

我使用FastAPI在 python3 上创建了 API ,Location 模型基于Pydantic 的BaseModel。

为了说明这一点,我定义了一个测试路线如下:

class Location(BaseModel):
    lat: float
    lng: float


@router.get('/test_404')
async def test_404(origin: Location = Body(...),
                   destination: Location = Body(...)):
    print(origin)
    print(destination)
    return {'res': 'ok'}

该路由应在请求的正文中采用两个参数:起点和终点,但仅当我在本地部署时才这样做。这个 :

url_local = "http://0.0.0.0:8080/test_404"
data = {
    'origin': {'lat': 104, 'lng': 342},
    'destination': {'lat': 104, 'lng': 342}
}
resp = requests.get(url_local, json = data)
print(resp.text)

输出:

'{"res":"ok"}'

当我在 Cloud Run 上部署相同的服务时会出现问题。我的所有其他路线都可以正常工作,但这是我将上面的代码与容器 url 一起使用时得到的输出:

    <!DOCTYPE html>\n
    <html lang=en>
    <meta charset=utf-8>
    \n
    <meta name=viewport content="initial-scale=1, minimum-scale=1, width=device-width">
    \n <title>Error 400 (Bad Request)!!1</title>\n
    \n <a href=//www.google.com/><span id=logo aria-label=Google></span></a>\n
    <p><b>400.</b>
        <ins>That’s an error.</ins>
        \n
    <p>Your client has issued a malformed or illegal request.
        <ins>That’s all we know.</ins>

这是由 google 触发的错误,不会让我的请求到达服务(无日志条目)

我在网上搜索过,但没有找到导致此错误的原因。我错过了什么?

非常感谢

标签: python-3.xgoogle-cloud-platformgoogle-cloud-runfastapipydantic

解决方案


它可能与这篇文章有关,其中用户体验到类似的消息。经过一些阅读并看到您的示例,我认为解决方案在于 REST best practice

严格来说,GET 请求在执行请求时不应发送任何数据,除了包含在 URI 中的任何数据。从技术上讲,一切皆有可能,但您应该使用查询参数而不是发送正文。

一些 API 包装器(如 Cloud Run)可能不接受这种行为,而在您的本地测试中它似乎可以工作。其他 API 包装器可能只接受带有 GET 请求的主体。我建议坚持 REST 最佳实践,你很好。


推荐阅读