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
    • 最新
    • 标签
主页 / server / 问题 / 1052645
Accepted
emte
emte
Asked: 2021-02-07 10:07:45 +0800 CST2021-02-07 10:07:45 +0800 CST 2021-02-07 10:07:45 +0800 CST

openvpn 服务器未使用 tcpdump 显示流量

  • 772

我有一个 OpenVPN 服务器和两个客户端,

我可以相互 ping 客户端,但是当我这样做时,我在使用 tcpdump 的服务器上看不到任何数据包

服务器

在 192.168.0.1 上运行

我尝试使用捕获流量tcpdump -i tun0 icmp --immediate-mode -l -n

客户

在 192.168.0.2 上运行

我可以ping client2 ping 192.168.0.3,它可以很好地解决:

PING 192.168.0.3 (192.168.0.3) 56(84) bytes of data.
64 bytes from 192.168.0.3: icmp_seq=1 ttl=128 time=32.4 ms

TCP 转储

但我从 tcpdump 看不到任何东西:

0 packets captured
0 packets received by filter
0 packets dropped by kernel

虽然如果我直接 ping openvpn 服务器ping 192.168.0.1,我可以看到在那里捕获的数据包:

18:05:04.022747 IP 192.168.0.2 > 192.168.0.1: ICMP echo request, id 5, seq 5, length 64
18:05:04.022801 IP 192.168.0.1 > 192.168.0.2: ICMP echo reply, id 5, seq 5, length 64

如何在服务器上捕获客户端间的通信数据包?

routing openvpn tcpdump
  • 1 1 个回答
  • 1080 Views

1 个回答

  • Voted
  1. Best Answer
    Nikita Kipriyanov
    2021-02-07T11:31:45+08:002021-02-07T11:31:45+08:00

    如果使用client-to-client选项,则无法通过 tcpdump 看到它。在这种情况下,OpenVPN 不会将任何流量转发到内核。它接收一个数据包,处理它并发送到另一个客户端,但由于它不是发往服务器系统,也不是通过它路由的,因此不需要将它发送到tun设备。

    您可以使用管理控制台和高详细级别 (6) 查看流量是否在 OpenVPN 内部:

    在服务器配置文件中:

    ...
    management localhost 7505
    ...
    

    利用:

    $ telnet localhost 7505
    ...
    >INFO:OpenVPN Management Interface Version 1 -- type 'help' for more info
    log on
    SUCCESS: real-time log notification set to ON
    verb 6
    SUCCESS: verb level changed
    >LOG:1612639797,D,XXXX/XXX.XXX.XXX.XXX:XXXXX UDPv4 READ [XXX] from [AF_INET]XXX.XXX.XXX.XXX:XXXXX (via [AF_INET]XXX.XXX.XXX.XXX%XXX): P_DATA_V2 kid=2 DATA len=XXX
    >LOG:1612639797,D,XXXX/XXX.XXX.XXX.XXX:XXXXX TUN WRITE [XXX]
    >LOG:1612639797,D,XXXX/XXX.XXX.XXX.XXX:XXXXX TUN READ [XXX]
    >LOG:1612639797,D,XXXX/XXX.XXX.XXX.XXX:XXXXX UDPv4 WRITE [XXX] to [AF_INET]XXX.XXX.XXX.XXX:XXXXX (via [AF_INET]XXX.XXX.XXX.XXX%XXX): P_DATA_V2 kid=2 DATA len=XXX
    ...
    log off
    SUCCESS: real-time log notification set to OFF
    verb 3
    SUCCESS: verb level changed
    exit
    $
    

    (在这种情况下,我不得不盲目地写“注销”,因为实时日志完全干扰了输出。我在繁忙的服务器上完成了这个。但它仍然有效。)

    详情请参阅man openvpn。请注意,如果使用,所有内容也会到达服务器日志文件,并且对于大量流量,日志会非常大。AFAIK 你甚至可以让它以十六进制形式记录数据包数据。

    • 4

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • 将路由永久添加到 Solaris 10

  • Quagga 套件中的 ./configure --disable-zebra 代表什么?

  • 使用特定接口进行出站连接(Ubuntu 9.04)

  • Linux TC/策略路由工具

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve