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 / 问题 / 787076
Accepted
Adrian
Adrian
Asked: 2024-11-23 07:26:28 +0800 CST2024-11-23 07:26:28 +0800 CST 2024-11-23 07:26:28 +0800 CST

为什么当客户端可以访问服务器时,netcat 在 UDP 模式下监听时无法访问客户端,而为什么 netcat 不打印任何内容?

  • 772

我正在使用全新安装的 Ubuntu 服务器 24.04.1 LTS。我以 root 身份运行以下命令来设置网络并进行一些实验:

apt install netcat-traditional

ip netns add ns1
ip netns add ns2

ip link add my_veth1 type veth peer name my_veth2

ip link set my_veth1 up netns ns1
ip link set my_veth2 up netns ns2

ip -n ns1 address add 1.2.3.4 dev my_veth1
ip -n ns1 route add 2.3.4.0/24 dev my_veth1

ip netns exec ns2 nc -u -l -p 8080

然后我从另一个终端运行它:

ip netns exec ns1 nc -u 2.3.4.5 8080 <<< 'Hello world from network namespace ns1'

UDP 是一种无连接协议。如果我的理解正确,这应该意味着来自网络命名空间 ns2 的 netcat UDP 服务器应该能够打印来自 ns1 的客户端发送的消息,无论服务器是否可以到达客户端,因此理论上我不必在 中配置路由ns2或在 中配置 ip 地址my_veth2。但是,除非同时配置了 ip 地址和路由表条目,否则第一个终端中不会打印任何消息。为什么?

  • 我尝试添加 IP 地址2.3.4.5,my_veth2但没有作用。
  • 我尝试创建一个新的路由表条目ns2来将所有流量重定向1.2.3.0/24到,my_veth2但这也不起作用。
  • 2.3.4.5仅当将 IP 地址添加到my_veth2并在 ns2 中创建新的路由表条目以将所有流量从 重定向1.2.3.0/24到时,才会打印该消息my_veth2。这是为什么?

编辑:禁用 rp_filter 似乎不起作用:

ip netns exec ns1 dd of=/proc/sys/net/ipv4/conf/all/rp_filter <<< '0'
ip netns exec ns2 dd of=/proc/sys/net/ipv4/conf/all/rp_filter <<< '0'
ip netns exec ns1 dd of=/proc/sys/net/ipv4/conf/my_veth1/rp_filter <<< '0'
ip netns exec ns2 dd of=/proc/sys/net/ipv4/conf/my_veth2/rp_filter <<< '0'

编辑2:安装并运行 tcpdump 我了解到有一些发送的 ARP 请求没有得到响应:

$ ip netns exec ns1 tcpdump -l -i my_veth1
23:38:14.402259 ARP, Request who-has 2.3.4.5 tell 1.2.3.4, length 28
23:38:14.402259 ARP, Request who-has 2.3.4.5 tell 1.2.3.4, length 28
23:38:14.402259 ARP, Request who-has 2.3.4.5 tell 1.2.3.4, length 28
...

ns2 my_veth2 给出相同的输出

因此我尝试手动创建 ARP 表条目...

ip -n ns1 neighbour add 2.3.4.5 dev my_veth1 lladdr $(ip netns exec ns2 cat /sys/class/net/my_veth2/address)

现在显然 UDP 数据包正在被发送

$ ip netns exec ns1 tcpdump -l -i my_veth1
00:24:15.164245 IP 1.2.3.4.36170 > 2.3.4.5.8080: UDP, length 39

ns2 my_veth2 给出相同的输出

但是,第一个运行 UDP netcat 服务器的终端仍然没有输出任何内容。为什么?


编辑 3:完成上述所有操作后,我尝试为以下设备分配一个 IP 地址my_veth2:

ip -n ns2 address add 2.3.4.5 dev my_veth2

现在,当我发送 UDP 数据包时,在以监听模式运行 netcat 的终端中出现此错误:

no connection : Network is unreachable

为什么?我的意思是,当然网络无法连接,但这不应该阻止服务器接收和显示 UDP 数据包。事实上,只有在收到 UDP 数据包时才会显示该错误。所以即使它知道它无法应答,它也应该能够接收和显示消息,对吧?

routing
  • 2 2 个回答
  • 71 Views

2 个回答

  • Voted
  1. Best Answer
    Steffen Ullrich
    2024-11-25T14:37:20+08:002024-11-25T14:37:20+08:00

    您最初仅在 ns1 上创建一个 IP 地址“IP1”,并在 ns2 上创建一条到虚构的(不存在的)IP 地址“IP2”的路由。

    尝试从 ns1 发送到 IP2 也会失败,因为它需要一个(链路层)MAC 地址来传送数据包。因此您会看到 ARP 请求。ns2 不会响应 IP2 的 ARP 请求,因为它没有 IP2。

    在 ns1 上手动添加 IP2 的 ARP 条目可以解决此链路层问题。在 ns2 上现在可以观察到来自 ns1 的数据包。

    但是 netcat 仍然不会显示任何内容,因为它只期望 0.0.0.0 上的数据包 - 这意味着 ns2 中配置的任何 IP 地址。只有 IP2 未在 ns2 中配置。因此,即使数据包在链路层被接收,也不会在网络层 (IP) 上进行处理 - 根本没有与数据包目的地匹配的 IP 地址。

    仅当 IP2 被添加为 ns2 的 IP 后,ns2 中的网络层才会对其负责并将有效负载传递给应用程序 (nc)。

    • 1
  2. Adrian
    2024-11-27T07:33:57+08:002024-11-27T07:33:57+08:00

    回答我自己的第三次编辑......

    我不知道在这种情况下决定拒绝 UDP 数据包的真正原因,但我能想到这样做的几个原因:

    1. 安全性:在这种情况下,数据包的 IP 地址很可能是被伪造的,而且这通常是出于恶意。例如 DDoS。
    2. 用它做任何事情都是没有意义的,因为你应该在客户端和服务器之间建立某种通信,但你无法做到这一点,因为你无法回答。如果你打开 2 个终端并使用 netcat 在两者之间建立 UDP 连接,你会看到不仅可以从客户端向服务器发送 UDP,还可以从服务器向客户端发送 UDP。UDP 通信应该是这样的:双向,而不仅仅是单向。如果通信不能双向进行,那又何必呢?只需发送一条错误消息并退出,这是没有希望的。
    • 0

相关问题

  • iptables:透明 tcp 流量代理

  • iptables -j REDIRECT *actually* 对数据包头做了什么?

  • 永久更改接口的指标

  • 任何为第 3 层交换/路由构建的发行版?

  • Debian 9;为 www 服务器设置网络设备

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