【网络】ICMP消息与ARPing详解

文章目录

1、ICMP消息与ARPing详解

ICMP(Internet Control Message Protocol)

基本概念

ICMP是网络层协议,主要用于网络诊断和错误报告。

常见ICMP消息类型

  • Echo Request/Reply(ping命令使用)
  • Destination Unreachable(目标不可达)
  • Time Exceeded(超时,traceroute使用)
  • Redirect(重定向)
  • Source Quench(源抑制)

ARP(Address Resolution Protocol)

基本概念

ARP是链路层协议,用于将IP地址解析为MAC地址。

ARP工作原理

  1. 主机发送ARP广播询问"谁有这个IP地址?"
  2. 目标主机回复自己的MAC地址
  3. 发送方缓存此IP-MAC映射

ARPing工具

定义

ARPing是一个使用ARP协议而不是ICMP来检测主机存活的网络工具。

使用场景

使用ARPing的场景

bash 复制代码
# 1. 检测局域网主机是否存活(即使ICMP被禁用)
arping 192.168.1.100

# 2. 获取设备的MAC地址
arping -c 1 192.168.1.1

# 3. 检测IP地址冲突
arping -D 192.168.1.50
# 如果返回多个MAC地址,说明存在IP冲突

# 4. 定位网络中的设备
arping -c 2 -I wlan0 192.168.1.254

# 5. 检查ARP缓存是否有效
arping -U 192.168.1.1

使用ICMP Ping的场景

bash 复制代码
# 1. 测试端到端网络连通性
ping google.com

# 2. 跨网段网络测试
ping 8.8.8.8

# 3. 测量网络延迟和丢包率
ping -c 10 -i 0.2 192.168.1.1

# 4. 持续监控网络状态
ping -t 192.168.1.1

故障排查流程示例

场景:无法访问某局域网设备

bash 复制代码
# 步骤1:先用ARPing检查设备是否在本地网络
$ arping -c 2 192.168.1.100
ARPING 192.168.1.100 from 192.168.1.10 eth0
Unicast reply from 192.168.1.100 [00:11:22:33:44:55]  0.543ms
# ✅ 设备在线,获取到MAC地址

# 步骤2:再用ICMP Ping测试网络连通性
$ ping -c 2 192.168.1.100
PING 192.168.1.100 (192.168.1.100) 56(84) bytes of data.
64 bytes from 192.168.1.100: icmp_seq=1 ttl=64 time=0.567ms
# ✅ ICMP也可达

# 步骤3:如果ICMP不通但ARPing通,可能是防火墙问题
$ ping 192.168.1.100
# 无响应 ❌
$ arping 192.168.1.100
# 有响应 ✅
# 结论:目标主机禁用了ICMP回应,但ARP正常工作

当ICMP不通但ARPing通时,通常是以下几种情况:
主要原因分析

bash 复制代码
1. 目标主机防火墙禁ping(最常见)
bash
# 检查目标主机的防火墙设置(如果可访问)

# Linux系统常见检查
# 查看iptables规则
sudo iptables -L -n | grep icmp
sudo iptables -L -n | grep INPUT | grep DROP

# 查看firewalld规则(CentOS/RHEL/Fedora)
sudo firewall-cmd --list-all | grep icmp

# Windows系统
# 通常Windows防火墙默认禁ping
# 可检查:控制面板 → Windows Defender防火墙 → 高级设置 → 入站规则
2. 网络设备过滤ICMP
bash
# 可能是中间路由器/交换机/防火墙设备过滤了ICMP
# 检查方法:
traceroute -n 192.168.1.100
# 如果到某一跳后停止,可能是该设备过滤ICMP
3. 目标系统ICMP配置
bash
# Linux系统检查ICMP回应设置
cat /proc/sys/net/ipv4/icmp_echo_ignore_all
# 0 = 允许回应(默认)
# 1 = 禁止回应

# 临时开启(如果可访问目标机)
echo 0 > /proc/sys/net/ipv4/icmp_echo_ignore_all

# 永久开启(需要root)
echo "net.ipv4.icmp_echo_ignore_all = 0" >> /etc/sysctl.conf
sysctl -p
相关推荐
摸鱼仙人~2 小时前
告别 Axios?轻量级 HTTP 客户端 ky 深度解析
网络·网络协议·http
Web极客码2 小时前
WordPress维护指南
服务器·网络·wordpress
FreeBuf_2 小时前
Mandiant 发布彩虹表工具集,可破解 NTLMv1 管理员密码
网络·安全
芯盾时代2 小时前
航空行业信息网络安全现状和需求
网络·安全·web安全
皇夜_2 小时前
【AI发电】P2P文件传输网站
网络·网络协议·p2p
科技圈快讯2 小时前
工程机械制造国产 CAD技工经验数字化传承应用
网络
尼古拉斯·纯情暖男·天真·阿玮2 小时前
实验七 RIP与OSPF实验
网络·智能路由器
budingxiaomoli3 小时前
网络编程套接字
网络
阿拉伯柠檬3 小时前
网络层与网络层协议IP(一)
linux·网络·网络协议·tcp/ip·面试