我需要从移动设备发送相当大的 HTTP 请求。在什么情况下请求丢失(因此必须重新发送发送的数据)?
例如,如果几秒钟没有无线电连接会发生什么?它是否取决于我无法控制的网络中的某些决定?
服务器上没有超时。我控制客户端,我们可以假设它是稳定的。这些调用进入了一些 Curl 库(POSIX C++,嵌入式 Linux),并且我可以更改它的数量有限。
请求丢失的一些情况:
然后是服务器端的所有问题,如内存不足、请求超时等......
如果可能,尝试将信息分成更小的部分。如果出现问题,需要重新发送的信息就会减少。
2011-01-27 更新:
当我说有太多事情可能出错并且如果有任何事情可能出错时,我可能听起来有点悲观。
在发送方,很容易检查传输是否成功,服务器是否发送了某种确认。它可以作为传输请求的答案发送,也可以通过单独的查询发送。
根据您在服务器端使用的内容,您可能能够检测到连接是否丢失(并且该请求的所有数据也可能丢失)。我的观点是,发送者有责任检查传输是否成功,如果不成功则重新发送。
我不知道你有什么样的数据,但我很确定可以将它分成更小的块。但是,我无法决定它是否可取。但是,如果您有移动设备并且传输数据需要很长时间,则可能是这样。
正如“某些人”所说,您应该将您的上传分成几部分,对它们进行编号并在另一端重新组装它们。我曾经写过一个网络服务来做到这一点,所以客户端可以确认已收到带有正确校验和(例如 SHA-1 哈希)的特定部分。
如果由于超时或哈希不匹配而没有收到确认,则客户端应重新发送该部分。我建议使每个块足够小,例如 1-10 kb,具体取决于预期的网络速度(慢速网络较小的块)。