【网络】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
相关推荐
2401_8818283214 分钟前
交换综合实验报告
网络
d111111111d16 分钟前
了解Modbus
网络·笔记·stm32·单片机·嵌入式硬件·学习
Hui_AI72022 分钟前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
程序员JerrySUN30 分钟前
Jetson边缘嵌入式实战课程第二讲:JetPack 和 SDK Manager 是什么
c语言·开发语言·网络·udp·音视频
忡黑梨34 分钟前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
pengyi8710151 小时前
共享 IP 池多人使用 分层权限与配额管理方案
运维·服务器·网络
S1998_1997111609•X1 小时前
论next/js在打击省份及犯罪行为集团的系统分析[特殊字符]设计
网络·数据库·百度·ssh·开闭原则
不做无法实现的梦~2 小时前
PX4 机载电脑 Linux 环境安装、串口、网络、ROS 完整配置
linux·运维·网络
byoass2 小时前
企业云盘权限管理深度对比:巴别鸟、联想Filez、腾讯企微云盘
网络·安全·云计算·企业微信
忡黑梨3 小时前
eNSP_路由策略
运维·服务器·网络·华为·智能路由器·负载均衡