【网络】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
相关推荐
M1582276905510 小时前
TCP转LORA产品说明及应用案例
网络·网络协议·tcp/ip
旖旎夜光10 小时前
Linux(13)(中)
linux·网络
来可电子CAN青年10 小时前
CAN总线远距离传输老断网?Fx灯不闪别慌,这几招让你的通信“稳如泰山”!
网络
独行soc10 小时前
2026年渗透测试面试题总结-18(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
云小逸10 小时前
【nmap源码解析】Nmap OS识别核心模块深度解析:osscan2.cc源码剖析(1)
开发语言·网络·学习·nmap
自不量力的A同学10 小时前
Solon AI v3.9 正式发布:全能 Skill 爆发
java·网络·人工智能
ESBK202511 小时前
第四届移动互联网、云计算与信息安全国际会议(MICCIS 2026)二轮征稿启动,诚邀全球学者共赴学术盛宴
大数据·网络·物联网·网络安全·云计算·密码学·信息与通信
莽撞的大地瓜11 小时前
洞察,始于一目了然——让舆情数据自己“说话”
大数据·网络·数据分析
那就回到过去12 小时前
MSTP路由协议简介
网络·网络协议·tcp/ip·ensp
浩浩测试一下12 小时前
内网---> WriteOwner权限滥用
网络·汇编·windows·安全·microsoft·系统安全