当套接字连续接收到超出程序处理能力的数据时会发生啥?

Posted

技术标签:

【中文标题】当套接字连续接收到超出程序处理能力的数据时会发生啥?【英文标题】:What happens when a socket continuously receives more data than the program can process?当套接字连续接收到超出程序处理能力的数据时会发生什么? 【发布时间】:2012-11-19 13:33:13 【问题描述】:

我有一个从安全摄像头下载图像流的应用程序(每个摄像头一个线程)。我向相机发出获取请求,相机通过发送无尽的 jpg 图像流来响应。

如果摄像头向程序发送数据的速度快于程序处理数据的速度,那么应用程序的行为是什么?现在我注意到计算机的已用内存上升到 95%,然后一直停留在那里,但是这个已用内存没有附加到任何特定的进程。这是因为套接字缓冲区不断扩展到某个点,然后当它们无法进一步扩展时才开始丢弃数据包?

我正在使用 .Net 套接字,如果这很重要的话。

【问题讨论】:

【参考方案1】:

如果“流”是指 TCP,则内核套接字接收缓冲区将填满,操作系统网络堆栈将应用 TCP flow control 以减慢发送者的速度。

另一方面,如果您正在使用 UDP,那么在某些时候您的接收器将开始丢弃数据包,除非您在应用程序级协议中有一些排序,否则您不会知道它。

【讨论】:

以上是关于当套接字连续接收到超出程序处理能力的数据时会发生啥?的主要内容,如果未能解决你的问题,请参考以下文章

当调用winsock 中的recv 函数并且没有收到所有数据时会发生啥?

当 getline() 读取的行大于系统内存时会发生啥?

当事件触发并尝试在不再存在的对象中执行事件处理程序时会发生啥?

尝试连接到已经处理请求的套接字的传入连接会发生啥?

当支持 SPDY 的浏览器收到 HTTP2 (H2) 响应时会发生啥?

当应用程序在 Cordova 中退出时会发生啥事件?