- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有一个在两个终端系统之间有 Ipsec 隧道的设置。当我在传出接口(interface)(例如 eth0)上捕获数据包时,我只能看到从我的系统发出的加密 ESP 数据包。我必须去查看接收端以查看实际传输的内容,即在接收端我可以看到解密后的数据包。接收方发送的 ack 也类似。它在 linux 内核中实际上是如何工作的?有没有办法在加密之前在 tcpdump 中查看发送方的数据包?
最佳答案
你的问题有3个问题:
第三个问题的答案是
这取决于您的内核和您使用的实现。如果您在 2.4 内核中使用 KLIPS 作为任何 *swan 解决方案的一部分,那么是。
否则,如果您使用的是使用 KAME/*BSD 模型的 2.6 内核
不,除非您更改 Ipssec 或 iptables 配置,以便将数据包发送到另一个未加密的接口(interface),然后将未加密的数据包转发到将在其上加密的接口(interface)。
第一个问题的答案是更改您的 iptables 配置和 IPSec 配置。
这种方式可以在加密数据之前在加密接口(interface)上进行 tcpdump 而无需更改任何内容。
对于 KLIPS 和 2.4 内核,它就像使用 -i 开关将 tcpdump 中的接口(interface)指定为 ipsec0 一样简单。
查看未加密数据的其他选项包括使用带有 -E 标志和相关参数 (see man page) 的 tcpdump,它在数据加密后解密数据,或者使用 tcpdump 捕获加密数据,然后在 Wireshark 中解密(更多有关 Wireshark 中 IPSec 的 ESP 解密的信息位于 here )。
或者,您可以在源代码中使用 printk 或 printk_times 将检测放置到 xfrm或 esp_input .
关于第二个问题,有几张图片解释了它如何在高层次上工作,包括解释 Solaris 实现作为 Oracle's System Administration Guide: IP Services 的一部分的图片。和 Linux's Foundation Network Flow through the kernel diagram .
另见以下 reference .基本上,无论是使用 setkey 的手动配置还是使用用户空间中的 IKE 守护进程的自动配置,都会将信息传递给 XFRM,然后 XFRM 在数据包到达 netfilter 预路由之前对其进行转换。
参见 here有关 KLIPS 和 KAME 历史的更多信息。
关于linux - 如何在加密之前在 tcpdump 中查看传出的 ESP 数据包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21931614/
如何告诉tcpdump解析名称并保留未解析的端口号? 来自人: -n Don’t convert host addresses to names. This can be used to a
我正在使用 tcpdump 通过 wlan0 收集数据包数据。但是我发现很多数据包的长度为 0,如下图所示。嗯,长度为 0 的数据包...... tcpdump 可靠还是我错过了什么? 最佳答案 好的
运行“tcpdump -w 1.pcap”时需要限制文件大小。我尝试使用键“-C”来执行此操作,但是当我添加它时,我收到错误“权限被拒绝”。所以: > sudo tcpdump -w 1.pcap t
我正在通过网络适配器捕获 tcp/udp 数据包,并尝试分析数据包以获得一些统计指标,例如带宽速率或协议(protocol)效率。无论如何,我需要使用一些 CLI 工具来监视特定链路(源、目标、端口,
使用 tcpdump 在接口(interface)上捕获 LLDP 数据包的格式是什么? 我尝试了以下格式,但它不起作用: tcpdump -w test.pcap -i eth0 lldp -vv
我想使用 tcpdump 捕获网络流量,如果捕获的数据包增加为 10mb,我想创建另一个文件。我如何使用 tcpdump 安排此操作。请善意地帮助我。谢谢。 最佳答案 tcpdump -W 5 -C
使用 tcpdump 时,我似乎无法看到捕获的所有数据。具体来说,我似乎从帧头丢失了 6 个字节,我想知道是否有人可以解释原因。 为了说明这一点,我在 VMWare 上以仅主机网络配置设置了一个 Ub
我在使用 Android 应用程序中的 TCPDump 时遇到问题。它应该逐行读取 tcpdump 的输出并在我的应用程序中处理它。 问题是: 有时代码工作正常,它会立即读取捕获的数据包。但有时,Re
我都使用过,我的结论是我可以使用 tcpflow 从网页中读取 html 数据,但不能使用 tcpdump 这样做。我得到的最好的结果是一些丑陋的 ASCII 文本,其中有很多句点符号。 我的理解是
我需要在我的 Android 设备上执行 tcpdump 跟踪。 我的设置: 将tcpdump文件推送到sdcard adb push filepath/tcpdump /sdcard/tcpdump
我的电脑上有两个网络接口(interface)。 netstat -i Kernel Interface table Iface MTU Met RX-OK RX-ERR RX-DRP RX-
Linux中是否有诸如tcpdump之类的实用程序来捕获通过RDMA channel 传输的流量? (Infiniband/RoCE/iWARP) 最佳答案 旧线程,但仍然: 正如Roland指出的那
我有一个巨大的pcap文件(100GB),我对一小部分数据包感兴趣,我知道这些数据包的数量为5,000,000至5,000,020。 如何使用tcpdump读取pcap文件,按数据包编号(或范围)过滤
如何使用 tcpdump 捕获以太网帧并显示本地 PC 使用 UDP、ARP 和 ICMP 协议(protocol)之一发送或接收的任何帧。 我正在尝试这个命令: sudo tcpdump -e ud
我正在使用 tcpdump 捕获网络数据包,当我开始丢弃数据包时遇到问题。我运行了一个通过网络快速交换数据包的应用程序;导致网络带宽较高。 >> tcpdump -i eno1 -s 64 -B 91
是否可以指定tcpdump 测量接收和发送数据包的时间?我知道命令 tcpdump -c 100 指定 tcpdump 在收到 10 个数据包后应该停止。我想指定 tcpdump 在例如 5 分钟后停
运行以下命令时出现错误: sudo setcap cap_net_raw,cap_net_admin=eip /usr/bin/tcpdump* 这提供了以下错误: Failed to set cap
我可以为dst指定1个以上的tcpdump IP地址吗? 如果没有,如果我只想要两个特定目的地的流量,该如何很好地过滤信息? 非常感谢你! 最佳答案 是的,您可能有一个过滤器,其中包含多个通过“或”连
我正在寻找在 openwrt 上运行的 tcpdump 二进制文件。该网站仅显示必须构建的源代码。有人指向我包含预构建二进制文件的位置吗?谢谢。 最佳答案 我建议建立一个工作存储库,即: https:
在服务器 # nc -lp 2424 hi server hi client 1 2 3 在客户端 ➜ ~ nc 139.224.xxx.xx 2424 hi server hi client 1
我是一名优秀的程序员,十分优秀!