- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
从 an issue we're having 开始,我试图了解当进程忙于使用重复调用将数据(数千个 UDP 视频数据包 + 偶尔的 TCP 消息)写入套接字时 ARP 表更改的影响/影响 send()
.
似乎,无论出于何种原因,我们的进程(更准确地说:Live555 WIS-Streamer 的进程)被此事件绊倒/阻塞。
任何人都可以帮助我了解在这种情况下可能发生的情况 - 我们可能期望/从 send()
捕获的错误/返回状态是什么? ,我们如何在我们的代码中缓解这种情况?
我目前正在阅读题为 Understanding Linux network Internals
的信息手册(只有 1035 页)但是任何有助于加速调试过程的提示都非常感谢!
编辑添加:我不希望人们认为我忽略了有关端口状态或进程状态的问题,这个问题很少发生(平均每 24 小时一次)并且只发生在一个我们无法轻易访问的(远程)安装,我们正在努力在实验室中复制它,以便我们可以进行更详细的诊断,但系统看门狗会在问题发生后约 3 分钟内重置,所以到时候消息传到我们这里,它已经重新启动并开始正常工作。
编辑以添加 Wireshark 信息:我不确定在这里总结 wireshark 捕获的最佳方法(很难上传 ~1Tb 的捕获数据包!)但我会尝试。 Cam:X
& Cam:Y
是由两个相同的 Live555 WIS Streamer 实例从不同端口流式传输的两个 RTSP 视频流。服务器'A'和'B'是服务器上两个网卡的MAC。
数据包的顺序是这样的:
UDP Packet from Cam:X -> Server 'A'
UDP Packet from Cam:Y -> Server 'A'
UDP Packet from Cam:X -> Server 'A'
UDP Packet from Cam:Y -> Server 'A'
UDP Packet from Cam:X -> Server 'A'
UDP Packet from Cam:Y -> Server 'A'
ARP Packet to Cam from Server 'B' "<my IP> is now on 'B'"
Intel ANS Probe broadcast from Server 'B', Sender ID '1' team ID 'B'
Intel ANS Probe broadcast from Server 'A', Sender ID '2' team ID 'B'
<silence> from Cam:X
UDP Packet from Cam:Y -> Server 'B'
UDP Packet from Cam:Y -> Server 'B'
UDP Packet from Cam:Y -> Server 'B'
此时或前后流中没有其他数据包。英特尔 ANS 数据包并不总是与来自 NIC 的 ARP 一致,但我认为为了完整性起见我应该将它们包括在内。
这个问题似乎对时间非常敏感,我们定期从服务器看到这些“团队”ARP,而且它们给我们带来问题的机会只有一次——好像网络堆栈代码中有一个特定的点是对 ARP 表变化敏感。失败的并不总是同一个流实例,尤其是另一个实例(以及所有其他网络流量 - HTTP 等)继续正常工作。
这听起来像是成组的 NIC“不应该”像这个 session 中期那样的 ARP,但是当流量全是 UDP 时,它们当然不会知道任何 session 。
最佳答案
好吧,如果只是给一些closure为此,客户重新配置了他们不可靠的网卡,一切正常,所以不幸的是,对于好奇的人来说,这意味着没有人会花钱让任何人仔细研究可以做些什么来解决这个问题。
关于linux - ARP 表在 send() 调用期间/期间更改的影响,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35437799/
我很难理解为什么这段代码无法编译: use std::cell::{Ref, RefCell}; struct St { data: RefCell } impl St { pub f
我从Richard Blum的一本书《 C#网络编程》中读到有关套接字的信息。以下摘录指出,不保证Send()方法可以发送所有传递给它的数据。 byte[] data = new byte[1024]
我有以下程序,它必须一次读取 1MB 的文件,将其发送到服务器(每次总是 1MB)并返回哈希码: #include #include #include #include #include #
代码在底部。 第 207 行的 send() 命令本身可以正常工作。但是,当我在第 218 行添加 send() 命令时,第一个命令失败 - 给出错误“地址错误”。我已经确认第二个 send() 命令
标记包含 !Send 的类型背后的原因是什么?字段(如 Rc 或 NonNull )与 Send特征?例如,标准库的 LinkedList 以这种方式工作:它包含 Option>字段并实现 Send特
我是新手,我正在尝试学习 goroutines 中信号函数的一些基本用法。我在 go 中有一个无限循环。通过这个 for 循环,我通过 channel 将值传递给 goroutine。 我也有一个阈值
如果数据是从另一台计算机(首先)“发送”的,我如何设置我的套接字例程以“发送”(首先)或(切换)“接收”? 谢谢 通用代码: -(void) TcpClient{ char buffer[12
这个问题已经有答案了: Java multiple file transfer over socket (3 个回答) 已关闭 4 年前。 我正在使用 Java Socket 将文件发送到服务器,然后
根据以下示例中的类型,Go编译器似乎将执行两个完全不同的语义操作: chanA <-chanB 如果chanA是类型(chan chan <-字符串),则此操作会将本身类型chanB的类型(chan
我正在尝试在 VBA 中使用 WinSock2 从本地主机 TCP 流发送(以及稍后接收)数据。 目前,我主要尝试从此处复制客户端示例,https://msdn.microsoft.com/en-us
我在我的 Mac OS X Yosemite 控制台中看到了这个: AppleEvents: Send port for process has no send right, port=( port:
我知道Clojure的“代理”是ref,带有“操作”的添加工作队列。 Action 是使用ref的值在第一个位置调用的函数,可以将其传递给其他参数。操作将返回ref的新值。因此,“代理”是一种计算re
我无法将任何对象或数组传递给 IPCRenderer。 通过 ipcs 传递对象或数组时出现错误,我什至尝试通过使用 JSON.stringify 转换为字符串来发送,但它会将其转换为空对象字符串。
我正在使用unix scoket进行数据传输(SOCK_STREAM模式) 我需要发送超过100k个字符的字符串。首先,我发送一个字符串的长度-它是sizeof(int)个字节。 length = s
Clojure API 将这两个函数描述为: (send a f & args) - Dispatch an action to an agent. Returns the agent immedia
def send_Button(): try: myMsg = "ME: " + text.get() msg = text.get() con
Ruby 对象都有一个“发送”方法,但是,我正在尝试使用一个 Java 库 ( netty-tools ),它的一个接口(interface)上有一个“发送”方法。 用法应该是 java_obj.se
Feb 8, 2011 11:56:49 AM com.sun.xml.internal.messaging.saaj.client.p2p.HttpSOAPC onnection post SEVE
来自 man 2 send: MSG_MORE (since Linux 2.4.4) (…) Since Linux 2.6, this flag is also supported for UDP
我的网页中可以有一个按钮,用于将预填充的消息发送到特定号码吗? 我正在尝试 intent://send/+391234567890#Intent;scheme=smsto;package=com.wh
我是一名优秀的程序员,十分优秀!