设备出现无法访问故障,ping出现目的主机不可达host unreachable,系目的设备路由错误导致问题排查过程

本文主要是介绍设备出现无法访问故障,ping出现目的主机不可达host unreachable,系目的设备路由错误导致问题排查过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

     有同事找来,说他们组采购的5g核心网设备无法相互访问,ping不通,让协助处理。

       问了一下组网,两台核心网设备一个ip地址192.168.213.100,去ping另一台192.168.194.100,两台在同一交换机下的两个vlan,两个vlan都有各自的ip地址,192.168.213.1和192.168.194.1。组网如图:

现象ping的结果如下:

 核心网2ip为192.168.213.100的设备ping核心网1的ip192.168.194.100没回显,ping192.168.194.1

显示destination host  unreachable目标主机不可达。

无法访问目的主机的可能性:

1、对方没有开机,或者开机但没有接入对应的广播域,跨网段的ip的话,所属网关arp查询消息没有得到应答,直连路由的话,本机发出arp消息没有被应答。

2、对方ip不存在。

3、设备本身路由错误,没有对应访问的路由。这种情况是所有网卡状态down,没有任何直连路由和默认路由的情况。

4、设备自身路由错误,应该走默认网关的ping消息,认为是同一网段,发出arp查询消息,在广播域里没到得到应答。

无法访问目的主机,是icmp的错误消息,由网络节点发出,直连路由的网络节点是发出ping动作的设备自身ip地址。跨网段是经过的网络节点用正常时ip导通时的ip地址回icmp错误消息。根据ping消息打印返回节点的ip地址可以判断出是直连路由还是其他跨网段非本机节点回的消息。
 

     一般这种情况,我们需要根据打印错误的源ip地址来确定是自身错误还是节点错误,就是用自身ip打印的目的主机不可达还是其他路径上经过的节点ip打印的目的主机不可达?

 

      看到192.168.213.100去ping192.168.194.100不通,ping它的网关192.168.194.1回显目的主机不可达,而且是自身ip192.168.213.100的回显,这是自身发出arp消息,没有得到响应的结果,没有送到网关上去。难道设备本身有192.168.194.0的路由吗?

   查看自身ip地址如下图:

  

    奇怪,没有配置192.168.194.0/24的地址,也就没有这个网段的直连路由 ,为啥有目的主机不可达的打印?

用tcpdump进行抓包,tcpdump  -i  8  -nne  arp回车,另起一个ssh的连接,去ping192.168.194.1,发现从这个端口有arp查询192.168.194.1的消息发出,但没有得到响应。

    感觉路由有问题,查看路由表。

   发现核心网2的路由表里有192.168.194.0/24网段的直连路由表项,路由有问题,查看/etc/sysconfig/network-scripts/ifcfg-enp61s0f2,没有发现配置文件里有192.168.194.xx的ip地址。判断不是由ip配置生成的直连路由。

   让询问厂家,得知是他们出厂时,配置的一条直连路由。删掉后,ping结果正常。

确定问题由于直连路由错误导致。

用一个环境模拟,发现直连路由在指定dev  ethx的情况下是可以加上的。

如在一台18.250.0.4的主机上,添加ip  route   add  192.168.207.0/24 dev eth0是能加上的。

  ping一下,并 tcpdump一下看看。

 

 总结:

1.一个vlan的access口不会响应其他同一交换机下其他vlan的子接口arp查询请求消息。

2.当使用route  add  -net或者ip route add  时,指定dev  xxx时,会生成对应的直连路由。

3.有直连路由时,arp消息会从对应网口发出。

4.原来一直认为,直连路由是设备配置有对应ip后才会生成的,其实linux里是可以通过指定dev

来添加直连路由的。这是没有及时发现问题的纠结的地方。

5.添加路由时,不指定gw的就认为是直连路由。

这篇关于设备出现无法访问故障,ping出现目的主机不可达host unreachable,系目的设备路由错误导致问题排查过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/232491

相关文章

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一