百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

网络为什么有路由黑洞?带你认知网络的另一面

nanshan 2024-10-10 07:19 16 浏览 0 评论

写在前面

在NA时代,我们认为只要网络设备有路由条目,通信就一定正常,否则就无法通信,但到了NP,这个说法就不准确了。其实网络设备本身分为数据层面和控制层面。只有数据层面和控制层面都正常,这个通信才能保证OK。那么什么是控制层面和数据层面呢?

控制层面就是各种协议工作的层面。它的作用是通过控制和管理各种网络协议的运行,使得路由器/交换机能够对整个网络的设备、链路和运行的协议有一个准确的了解,并在网络发生变化时也能及时感知并调整。控制层面为数据层面转发数据提供了各种必要的信息。

数据层面是针对数据发送来说的。控制层面构建了路由表等数据发送的必要信息,数据层面根据这些信息来发送数据。网络设备中,对数据的各种具体的处理、转发过程都属于数据层面的范畴。数据层面主要占用的是硬件资源。了解这些之后,再来分析黑洞路由的产生,就不难了。

正文

该环境为5台路由器,环境为eNSP,相关的IP、路由协议为上图所示,R1---R2为EBGP,R2-R4为IBGP关系,R4---R5为EBGP关系,R2----R3----R4为OSPF area0环境。

查看各路由器的详细情况

在R1上发布自己的环回口(拓扑的中的主机)

[R1]bgp 100
[R1-bgp]network 1.1.1.1 32
--------------------------------
[R5]bgp 300
[R5-bgp]network 5.5.5.5 32

在R1和R5查看路由表,看是否学到

此时肯定没有,原因在下图

由于学到的路由的下一跳为45.45.45.2,在R2的本地路由表没有该跳路由,所以打为次优路由,不会放入路由表,此时只需要在BGP修改路由的下一跳为本地即可,再查看下路由表

[R2]bgp 200
[R2-bgp]peer 4.4.4.4 next-hop-local
-------------------------------------------
[R4]bgp 200
[R4-bgp]peer 2.2.2.2 next-hop-local

此时双方都有各自的路由,进行ICMP测试(带源测试)

实验到这里问题就出现了,为什么有双方的路由却不通?我们详细看下1.1.1.1到5.5.5.5的详细过程

R1访问5.5.5.5,由于是跨网段,需要查询路由表,查询到的路由表为

要去往5.5.5.5下一跳为12.12.12.2,也就是R2,所以在R2的接口上抓包证实了这个过程

此时包已经到了R2,在R2上查询路由表

此时发现去往5.5.5.5的下一跳为4.4.4.4,但4.4.4.4明显不是直连,所以继续查询去往4.4.4.4的路由

最终发现去往5.5.5.5的下一跳为23.23.23.2,即为R3,继续查询R3的路由

此时问题原因就出来了,就没有该条路由,从抓包结果可以看到

R3接R4抓包无信息,证明R3接收到该ICMP报文,但由于没有路由信息就直接丢弃。那么我们预想的情况是怎么样的呢?

至此,整个问题的原因就找到了,问题出在R3上并没有路由,因此导致出现了路由黑洞,通信异常。那么实际工作情况会遇到吗?肯定会,最常见的就是MPLS-VPN里,很多这样的场景,这种解决访问有几种

  • MPLS技术
  • 组成FULL Mesh组网
  • IGP、BGP重分发

由于2和3在现网中用的不多,所以讲解MPLS这种解决方案。MPLS解决的本质就是‘’欺骗路由器‘’,用标签构建控制层面,从而保证数据层面正常。命令十分简单(由于是实验环境,只涉及LDP分发标签)

[R2]mpls lsr-id 2.2.2.2
[R2-mpls]quit
[R2]mpls ldp
[R2-mpls-ldp]q
[R2]interface GigabitEthernet 0/0/1
[R2-GigabitEthernet0/0/1]mpls
[R2-GigabitEthernet0/0/1]mpls ldp
[R2-GigabitEthernet0/0/1]quit
[R2]route recursive-lookup tunnel ##使能迭代隧道功能
------------------------------------------------
[R3]mpls lsr-id 3.3.3.3
[R3-mpls]quit
[R3]mpls ldp
[R3-mpls-ldp]q
[R3]interface GigabitEthernet 0/0/0
[R3-GigabitEthernet0/0/0]mpls
[R3-GigabitEthernet0/0/1]mpls ldp
[R3-GigabitEthernet0/0/1]interface GigabitEthernet 0/0/1
[R3-GigabitEthernet0/0/1]mpls
[R3-GigabitEthernet0/0/1]mpls ldp
[R3-GigabitEthernet0/0/1]quit
[R3]route recursive-lookup tunnel
------------------------------------------------
[R4]mpls lsr-id 4.4.4.4
[R4-mpls]quit
[R4]mpls ldp
[R4-mpls-ldp]q
[R4]interface GigabitEthernet 0/0/0
[R4-GigabitEthernet0/0/0]mpls
[R4-GigabitEthernet0/0/1]mpls ldp
[R4-GigabitEthernet0/0/1]quit
[R4]route recursive-lookup tunnel

查看是否OK

此时访问正常,那么实验过程结束

总结

路由黑洞产生的本质为控制层面不通,控制层面在构建路由的时候因为协议的特性,导致配置存在缺陷,从而出现该现象。避免该问题可以通过网络的设计或协议巧妙的搭配,最后再说一句,问题的本质一定是有原因的,并非偶然,通过底层看本质,你会对协议更加了解,在后续MPLS-VPN会更加的详细描述黑洞路由的利用。

相关推荐

爆肝 30 天!从 JVM 调优到百万级 QPS,我的 Java 性能飞升全记录(2)

前言:从崩溃边缘到百万级QPS的逆袭凌晨3点的办公室,监控大屏突然飙红,QPS从5万断崖式下跌到800,CPU满载报警,GC时间突破3秒大关——这是我们的电商大促系统在压测中遭...

如何彻底清除服务器上的恶意软件与后门 ?

当服务器遭受入侵后,清除恶意软件和后门是恢复系统安全性的关键步骤。如果清除不彻底,攻击者可能通过隐藏后门程序再次发动攻击。以下是一个系统化的操作指南,帮助您彻底清除服务器上的恶意软件和后门,同时加强服...

Docker 部署高性能抖音 TikTok数据爬取工具,支持无水印视频下载

一、项目简介此项目基于PyWebIO、FastAPI和HTTPX,是一个高效的异步数据爬取工具,专注于抖音/TikTok平台的数据提取。通过Web端界面,用户可以在线批量解析并下载无水印的视频或...

我如何将Unix时间转换为可读的值?

高频处理时间问题在处理时间值时,程序中的一种常见方法是将其转换为线性刻度表示。无法将"2005年1月17日下午5:37"这样的日期存储为变量,并期望能够进行任何操作。因此,在合格的程序...

用shell进行ASCII字符转换与URL编码技巧

如何将ASCII字符转换为十进制(或十六进制)值并进行相反的转换?如何进行URL编码和URL解码?如果你在编写脚本时已知八进制或十六进制值,你可以使用printf命令实现:#POSIXprintf...

Linux远程shell登录出现bash-4.2#问题

出现以上问题的原因是/root目录下丢失了.bashrc和.bash_profile文件/etc/skel/.bash_profile和/etc/skel/.bashrc的文件复制到/root下即可命...

三部门:推进算力互联互通 推动国家枢纽节点和需求地之间400G/800G 高带宽全光连接

每经AI快讯,1月6日,国家发展改革委等三部门印发《国家数据基础设施建设指引》。其中提出,加强新兴网络技术创新应用,优化网络计费方式,降低东西部数据传输成本,促进东部中高时延业务向西部转移。推进算力互...

三部门:推动国家枢纽节点和需求地之间400G/800G高带宽全光连接

国家发展改革委、国家数据局、工业和信息化部等印发《国家数据基础设施建设指引》的通知。其中提到,加强新兴网络技术创新应用,优化网络计费方式,降低东西部数据传输成本,促进东部中高时延业务向西部转移。推进算...

高带宽低延迟如何开启?实际效果如何?

在上次的《实测AMD平台玩游戏用什么频率的内存更好?》中通过测试已经得知,AMDCPU的最佳频率是6000,具体该如何选择,如何设置能提升游戏帧数,往下看小白新手也能看明白。内存选择6000频率内存...

排列五第22237期规律预测走势图分享

二定头尾:03458,X,X,035890XX00XX30XX50XX80XX93XX03XX33XX53XX83XX94XX04XX34XX54XX84XX95...

格式化字符串漏洞及利用_萌新食用

前言格式化字符串漏洞具有任意地址读,任意地址写。printfprintf--一个参数:情况1当参数只有1个字符串的话(含有%?),//?即i,x,s等等<br>第一个...

Linux配置ip地址的两种方法(linux配置ip详细步骤)

Linux配置ip地址的两种方法,实验环境为centos7.6方法1:nmcli工具配置(centos7以下版本不支持该方法)第一步,通过nmcliconnection查看网卡名称[root@lo...

排列五9月30日第22263期最新规律走势预测讲解

二定头尾:034589,X,X,0125670XX00XX10XX20XX50XX60XX73XX03XX13XX23XX53XX63XX74XX04XX14XX2...

GDB调试的高级技巧(gdb调试工具的使用)

GDB是我们平时调试c/c++程序的利器,查起复杂的bug问题,比打印大法要好得多,但是也不得不说,gdb在默认情况下用起来并不是很好用,最近学习到几个高级点的技巧,分享下:一美化打印先上个例子...

给NAS测评打个样:QNAP TS-251D双盘位NAS全面测评体验

这两年随着大家网络条件越来越好,视频、电影资源越来越丰富。以及智能手机的普及拍照也更加方便,大家对于存储的需求也越来越高。除了传统的优盘、移动硬盘之外现在私有云方面也有了更多的选择。那么日常私有云选购...

取消回复欢迎 发表评论: