使用WhatsApp API,我有一个非常简单的flask应用程序,它在2台服务器上运行,该应用程序仅在根地址处接受发帖请求并打印收到的内容。一台主机位于Traefik后面,另一台由我直接运行,因此flask的内置开发服务器可以直接暴露。第一个主机称为http://sub.domain.com/incoming/
,第二个主机使用IP http://12.34.56.78
。
在后者上,所有功能均按预期工作:我收到Twilio的回调,并且我也可以自己调用API并获得干净的响应(HTTP 200,<Response></Response>
作为正文)。在前一种情况下,如果我自己调用API,则可以正常工作,并且得到相同的输出。但是当Twilio发送其回调时,我在Twilio的调试器上始终遇到11200 HTTP检索失败。
我发现这种行为上的差异有些奇怪,但是还有一个细节我真的觉得有些奇怪-Twilio调试器可以选择“重播请求”,在这种情况下,它的回调可以重新发送。在发生检索失败的主机上,如果重播失败的请求,它们将始终成功!
在一切正常的服务器上,我存储了一个原始的Twilio请求(带有标头的HTTP等),并尝试使用netcat手动将此请求发送到发生故障的服务器(在更新Host标头字段之后)。当我这样做时,服务器响应没有任何问题,因此请求的结构似乎不是问题。
我真的很茫然,我已经没有足够的想法去寻找导致这个问题的原因了。有什么建议吗?