AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 543971
Accepted
Scott M
Scott M
Asked: 2019-09-27 18:40:45 +0800 CST2019-09-27 18:40:45 +0800 CST 2019-09-27 18:40:45 +0800 CST

Linux TCP,如何调试写入流的意外延迟?

  • 772

问题:我的音乐服务器代码使用阻塞套接字上的简单 TCP 连接,需要将字节流式传输到客户端(恰好是 Logitech 挤压盒)。这并不复杂 - 从文件中读取 64k,将其写入挤压箱,然后重复。它都在一个不忙的本地局域网上运行,服务器和squeezebox客户端插入同一个交换机。挤压盒不会很快消耗流,所以服务器,在几乎任何硬件上,都应该没有问题保持客户端的馈送。

而当服务器运行在树莓派 3B+ 上时,它实际上完全没有问题。pi 零可能会跟上。当它在我的 Linux 笔记本电脑上运行时,同上,一切都很好。我可以定期询问挤压箱它的内部缓冲区有多满,它很快就会达到大约 99+%,并保持在那里。如您所料,服务器 write()s(在前几个之后)大部分时间都被阻塞了。

但是我将服务器移动到运行 Linux 的 Azulle Inspire 上,插入同一个交换机,结果出现了可怕的错误。音乐开始播放,但很快就断断续续地消失了。挤压箱报告缓冲区开始填满,但随后出现了一些问题,缓冲区迅速清空(有时会稍微增加一点,所以我认为有些流量通过了,但还不够接近),音乐停止了。服务器声称它正在继续写入,尽管写入时间比我预期的要长。

请注意,Azulle 偶尔还有其他网络任务,它们都工作正常,尽管我可能不会注意到大多数其他应用程序的短暂网络延迟。但是当音乐服务器运行时,NUC(和网络)处于空闲状态——这不是 CPU 或带宽问题。

我尝试过更换电缆、更换开关并在开关上使用不同的端口。我试过发送不同的缓冲区大小。没有效果。我能想到的只是 TCP 堆栈或以太网硬件有一些非常不可靠的地方。

我该如何调试?流出来的 linux 笔记本电脑运行得很好,运行的是 Linux 4.15.0-55-generic(并且 apt upgrade 不会改变这一点)。Azuelle 运行的是 Linux 4.15.0-64-generic,Mint。我不敢相信 4.15.0 中的 TCP 处理发生了根本性的变化。我对tcpdump之类的工具不是很熟悉,更不用说内核配置或调试了,所以我正在寻找一些手把手...

linux 笔记本电脑和 Azuelle 之间的 ping 时间始终在 0.2 毫秒和 0.35 毫秒左右,典型值为 0.33 毫秒。

我迷路了。TIA。

tcp
  • 2 2 个回答
  • 709 Views

2 个回答

  • Voted
  1. V13
    2019-09-29T12:54:22+08:002019-09-29T12:54:22+08:00

    使用 tcpdump 捕获您的流:

    tcpdump -i iface -s 1500 -w out.cap 'tcp and port xxx'
    

    其中iface是网络接口,xxx是两个端口号之一。

    然后out.cap用wireshark打开,看看你能从trace中得到什么。那里发生了什么应该很明显。如果没有,请再次发布。

    FWIW,从您所说的来看,这听起来像是 MTU 问题。

    • 1
  2. Best Answer
    Scott M
    2019-09-29T16:34:06+08:002019-09-29T16:34:06+08:00

    嗯,这就是我需要的线索。

    当我对 MTU 大小感到好奇时,我发现了这一点:

    /sys/class/net/enp1s0/mtu:1500 /sys/class/net/lo/mtu:65536 /sys/class/net/wlp2s0/mtu:1500

    一切都很好,但 wlp 看起来像无线连接。无线?那还开着吗?所以我在 wlp... 界面上进行了 tcpdump,我看到了一条我从协议中识别出来的消息,然后是一长串的 ACK,没有别的,并且流播放了几秒钟的音乐并失败了。

    然后我关闭了无线并再次尝试。没有口吃。一切顺利。

    奇怪的是服务器距离无线接入点只有几英尺。即使它正在使用它,也不应该没有足够的带宽。我想知道由于某种原因,同时打开两者是否会导致问题,但我认为这是不可能的......

    • 1

相关问题

  • 创建套接字文件是否需要 AF_INET?

  • UDP 或 TCP 打孔以连接两个对等点(每个对等点位于路由器后面)

  • 通过 TCP 构建 Unix 套接字桥

  • 连接到 IP 0.0.0.0 成功。如何?为什么?

  • Linux中哪个进程负责TCP

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve