Golang监控网络流量核心是采集→解析→统计→可视化/告警四环节:通过读取/proc/net/文件实现无权限汇总监控,用gopacket抓包做协议级分析,结合/proc/PID/net/关联进程流量,并用Prometheus导出指标供Grafana展示。

用 Golang 监控网络流量,核心在于“采集 → 解析 → 统计 → 可视化/告警”四个环节。不依赖外部代理或系统级工具(如 ifconfig、nethogs),Golang 可通过系统接口 + 抓包库实现细粒度、进程级甚至协议级的流量观测。
Linux 系统在 /proc/net/ 下暴露了丰富的实时网络状态,无需 root 权限即可读取:
示例:每秒读取 eth0 的接收/发送字节数,计算瞬时速率:
func readNetDev() (rx, tx uint64, err error) {
data, _ := os.ReadFile("/proc/net/dev")
// 解析第2行起,跳过 header,匹配 "eth0:" 行
// 第2列 = rx_bytes,第10列 = tx_bytes
return rx, tx, nil
}
立即学习“go语言免费学习笔记(深入)”;
当需要按 IP、端口、协议(HTTP/DNS/TCP)甚至 payload 关键字做分类统计时,gopacket 是最常用方案:
pcap.OpenLive("eth0", 1600, false, 30*time.Second) 打开网卡gopacket.NewPacketSource(handle, handle.LinkType()) 构建数据包流ipLayer := packet.Layer(layers.LayerTypeIPv4)、tcpLayer := packet.Layer(layers.LayerTypeTCP)
注意:抓包需 root 权限,生产环境建议限制抓包长度(如 SnapLen=128)、过滤 BPF 表达式(如 "tcp port 80 or port 443")以降低开销。
单纯抓包无法知道哪个进程发的包。Golang 可通过以下方式关联进程与连接:
readlink 获取 inode 号可封装成定时扫描任务,每 5 秒更新一次各进程的实时上行/下行速率,适合做轻量级 nettop 类工具。
把流量数据变成可观测指标,推荐用 prometheus/client_golang 暴露:
net_bytes_total{direction="rx",interface="eth0"}、net_process_bytes{pid="1234",comm="nginx"}
metricsVec.WithLabelValues(...).Set(value)
http.Handle("/metrics", promhttp.Handler())
Prometheus 抓取后,就能在 Grafana 中画出带进程标签的流量热力图、TOP N 流量进程排行等。
基本上就这些。不需要复杂框架,几段 Go 代码就能搭出从网卡到进程的全链路流量监控能力。
以上就是如何使用Golang监控网络流量_Golang网络流量统计与分析方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号