登录
首页 >  文章 >  linux

Linux下安装Wireshark抓包教程

时间:2026-05-29 10:48:32 358浏览 收藏

本文详细解析了在Linux系统中安装与配置Wireshark(含tshark)以实现稳定抓包的核心难点与实操方案,直击权限不足、Qt环境异常、Wayland兼容性差及dumpcap能力缺失等常见故障根源,提供跨发行版(Ubuntu/Debian、Fedora、CentOS)的精准命令与分步修复策略,涵盖图形界面启动、非root用户授权、黑屏闪退应急处理、命令行高效分析及协议解析验证,助你快速摆脱“无法启动”“无权捕获”“界面空白”等困扰,真正掌握专业级网络诊断能力。

Linux怎么安装Wireshark抓包_Linux Wireshark和tshark使用教程【进阶】

如果您在 Linux 系统中需要进行网络协议分析与故障排查,但发现 Wireshark 图形界面无法启动、非 root 用户无法抓包、或命令行工具 tshark 报错“Permission denied”,则问题通常源于权限配置缺失、依赖组件未安装或 Qt 运行环境异常。以下是解决此问题的步骤:

一、安装 Wireshark 与核心组件

Debian/Ubuntu 系统默认仅预装命令行抓包工具 tshark,图形前端需显式安装 wireshark-qt;RHEL/CentOS/Fedora 则需确认仓库启用并安装完整包组。安装过程必须包含底层抓包引擎 dumpcap 及其依赖。

1、更新软件源索引:
sudo apt update(Ubuntu/Debian)或 sudo dnf makecache(Fedora)或 sudo yum makecache(CentOS 7)

2、安装图形化 Wireshark(推荐 Qt 版):
sudo apt install wireshark-qt libcap2-bin(Ubuntu/Debian)
sudo dnf install wireshark qt5-qtmultimedia(Fedora)
sudo yum install wireshark wireshark-qt(CentOS 7)

3、验证 tshark 是否可用:
tshark -v 应输出版本信息且无报错

二、授予非 root 用户抓包权限

Linux 内核禁止普通用户直接访问原始套接字,这是强制安全策略。仅添加用户至 wireshark 组不足以生效,必须为 dumpcap 设置 capability 权限,否则点击捕获按钮将提示“you don’t have permission to capture packets”或直接崩溃。

1、将当前用户加入 wireshark 组:
sudo usermod -a -G wireshark $USER

2、为 dumpcap 二进制文件赋予必要能力:
sudo setcap cap_net_raw,cap_net_admin+eip /usr/bin/dumpcap

3、确认权限已写入:
getcap /usr/bin/dumpcap 应返回 /usr/bin/dumpcap = cap_net_admin,cap_net_raw+eip

4、立即激活组权限(无需重启):
newgrp wireshark

三、修复 Wireshark 启动黑屏或闪退

Ubuntu 22.04+ 或 Fedora 系统上,Wireshark 常因 Wayland 显示协议兼容性问题或 Qt 插件路径混乱导致窗口一闪而过、界面卡死或仅显示空白。此时不应切换桌面环境,而应优先尝试轻量级运行时修复。

1、强制使用 X11 后端启动:
QT_QPA_PLATFORM=xcb wireshark

2、清除损坏的 Qt 配置(升级后尤其关键):
rm -rf ~/.config/Wireshark

3、若仍崩溃,检查是否缺失多媒体插件(仅 Fedora):
sudo dnf install qt5-qtmultimedia

四、使用 tshark 进行无界面抓包与分析

tshark 是 Wireshark 的命令行等价工具,适合服务器环境、脚本集成或自动化分析。它不依赖图形库,但同样受 cap_net_raw 权限约束,因此必须完成第二步权限配置后方可使用。

1、捕获指定网卡前 100 个数据包并保存:
tshark -i eth0 -c 100 -w capture.pcap

2、实时显示 HTTP 请求 URI:
tshark -i eth0 -Y "http.request" -T fields -e http.request.uri

3、过滤并导出 DNS 查询域名列表:
tshark -r capture.pcap -Y "dns.qry.name" -T fields -e dns.qry.name | sort -u

4、以人类可读格式输出 TCP 流内容(仅限未加密流量):
tshark -r capture.pcap -q -z follow,tcp,ascii,0

五、验证抓包结果与协议解析能力

Wireshark/tshark 能否正确解析应用层协议,取决于是否加载对应解码器及是否满足解密前提。例如 HTTP 可直接解析,而 HTTPS 默认仅显示 TLS 握手,明文内容不可见——这并非工具缺陷,而是加密协议设计使然。

1、确认 HTTP 协议可被识别:
打开 pcap 文件后,在过滤栏输入 http,应出现高亮 HTTP 数据包

2、检查 TLS 流是否标记为 Encrypted Application Data:
若存在 TLSv1.2/v1.3 流且无密钥,Wireshark 不会尝试解密,状态栏显示 [Encrypted Application Data]

3、验证 DNS 解析字段完整性:
选中任意 DNS 响应包,在 Packet Details 面板展开 DNS → Answers → Name,应可见可读域名

4、测试 ICMP 抓包有效性:
执行 ping -c 3 8.8.8.8 后,用 tshark -Y icmp 或 Wireshark 过滤器 icmp 应匹配到请求与回复

理论要掌握,实操不能落!以上关于《Linux下安装Wireshark抓包教程》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>