Linux查看 UDP 和TCP 流量received和sent数据字节大小

在 Linux 系统中,可以通过以下方法查看 UDPTCP 的流量(receivedsent 数据字节大小):


1. 使用 /proc/net/snmp 文件

/proc/net/snmp 文件包含了详细的网络统计信息,包括 TCP 和 UDP 的接收和发送字节数。

查看 TCP 和 UDP 的字节数
bash 复制代码
cat /proc/net/snmp

输出示例:

Ip: Forwarding DefaultTTL InReceives InHdrErrors InAddrErrors ForwDatagrams InUnknownProtos InDiscards InDelivers OutRequests OutDiscards OutNoRoutes ReasmTimeout ReasmReqds ReasmOKs ReasmFails FragOKs FragFails FragCreates
Ip: 1 64 123456 0 0 0 0 0 123456 987654 0 0 0 0 0 0 0 0 0
Tcp: RtoAlgorithm RtoMin RtoMax MaxConn ActiveOpens PassiveOpens AttemptFails EstabResets CurrEstab InSegs OutSegs RetransSegs InErrs OutRsts InCsumErrors
Tcp: 1 200 120000 -1 500 300 0 0 100 123456 987654 0 0 0 0
Udp: InDatagrams NoPorts InErrors OutDatagrams RcvbufErrors SndbufErrors InCsumErrors
Udp: 23456 0 0 12345 0 0 0
提取 TCP 和 UDP 的字节数
  • TCP 接收字节数(InSegs):

    bash 复制代码
    awk '/Tcp:/ {getline; print $10}' /proc/net/snmp
  • TCP 发送字节数(OutSegs):

    bash 复制代码
    awk '/Tcp:/ {getline; print $11}' /proc/net/snmp
  • UDP 接收字节数(InDatagrams):

    bash 复制代码
    awk '/Udp:/ {getline; print $4}' /proc/net/snmp
  • UDP 发送字节数(OutDatagrams):

    bash 复制代码
    awk '/Udp:/ {getline; print $5}' /proc/net/snmp

2. 使用 nstat 命令

nstat 是一个轻量级的工具,用于显示网络统计信息。

查看 TCP 和 UDP 的字节数
bash 复制代码
nstat -z

输出示例:

TcpInSegs        123456
TcpOutSegs       987654
UdpInDatagrams   23456
UdpOutDatagrams  12345
提取 TCP 和 UDP 的字节数
  • TCP 接收字节数:

    bash 复制代码
    nstat -z | grep TcpInSegs | awk '{print $2}'
  • TCP 发送字节数:

    bash 复制代码
    nstat -z | grep TcpOutSegs | awk '{print $2}'
  • UDP 接收字节数:

    bash 复制代码
    nstat -z | grep UdpInDatagrams | awk '{print $2}'
  • UDP 发送字节数:

    bash 复制代码
    nstat -z | grep UdpOutDatagrams | awk '{print $2}'

3. 使用 ss 命令

ss 可以显示 TCP 和 UDP 的统计信息,但默认不显示字节数。可以结合 /proc/net/snmpnstat 使用。


4. 使用 iptables 统计流量

如果需要更精确的统计,可以使用 iptables 来记录 TCP 和 UDP 的流量。

添加规则统计流量
bash 复制代码
sudo iptables -A INPUT -p tcp
sudo iptables -A OUTPUT -p tcp
sudo iptables -A INPUT -p udp
sudo iptables -A OUTPUT -p udp
查看统计结果
bash 复制代码
sudo iptables -L -v -n

输出示例:

Chain INPUT (policy ACCEPT 123456 packets, 98765432 bytes)
 pkts bytes target     prot opt in     out     source               destination
 1000 50000            tcp  --  *      *       0.0.0.0/0            0.0.0.0/0
 500  25000            udp  --  *      *       0.0.0.0/0            0.0.0.0/0

Chain OUTPUT (policy ACCEPT 987654 packets, 123456789 bytes)
 pkts bytes target     prot opt in     out     source               destination
 2000 100000           tcp  --  *      *       0.0.0.0/0            0.0.0.0/0
 1000 50000            udp  --  *      *       0.0.0.0/0            0.0.0.0/0
  • TCP 接收字节数 :查看 INPUT 链中 tcpbytes
  • TCP 发送字节数 :查看 OUTPUT 链中 tcpbytes
  • UDP 接收字节数 :查看 INPUT 链中 udpbytes
  • UDP 发送字节数 :查看 OUTPUT 链中 udpbytes

5. 使用 tcpdump 统计流量

如果需要精确统计 TCP 和 UDP 的字节数,可以使用 tcpdump 捕获流量并分析。

捕获 TCP 流量
bash 复制代码
sudo tcpdump -i eth0 tcp -w tcp_traffic.pcap
捕获 UDP 流量
bash 复制代码
sudo tcpdump -i eth0 udp -w udp_traffic.pcap
使用 tshark 分析流量
bash 复制代码
tshark -r tcp_traffic.pcap -qz io,stat,0
tshark -r udp_traffic.pcap -qz io,stat,0

总结

  • 使用 /proc/net/snmpnstat 可以快速查看 TCP 和 UDP 的字节数。
  • 使用 iptables 可以实时统计 TCP 和 UDP 的流量。
  • 使用 tcpdumptshark 可以精确分析 TCP 和 UDP 的字节数。
  • 根据需求选择合适的工具即可!
相关推荐
ChinaRainbowSea1 分钟前
Linux: Centos7 Cannot find a valid baseurl for repo: base/7/x86_64 解决方案
java·linux·运维·服务器·docker·架构
vortex525 分钟前
在Kali中使用虚拟环境安装python工具的最佳实践:以 pwncat 为例
linux·python·网络安全·渗透测试·pip·kali
LKAI.1 小时前
MongoDB用户管理和复制组
linux·数据库·mongodb
linux修理工1 小时前
moodle 开源的在线学习管理系统(LMS)部署
linux
熬夜苦读学习2 小时前
库制作与原理
linux·数据库·后端
晨曦启明7112 小时前
Linux云计算SRE-第十八周
linux·运维·云计算
暴躁的小胡!!!3 小时前
Linux权限维持之vim python 扩展后门(五)
linux·运维·服务器·网络·安全
亭墨3 小时前
linux0.11内核源码修仙传第五章——内存初始化(主存与缓存)
linux·c语言·驱动开发·学习·缓存·系统架构
追寻光3 小时前
Linux 配置静态 IP
linux
誓约酱3 小时前
(每日一题) 力扣 283 移动零
linux·c语言·数据结构·c++·算法·leetcode