网络为什么有路由黑洞?带你认知网络的另一面
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全面测评体验
-
这两年随着大家网络条件越来越好,视频、电影资源越来越丰富。以及智能手机的普及拍照也更加方便,大家对于存储的需求也越来越高。除了传统的优盘、移动硬盘之外现在私有云方面也有了更多的选择。那么日常私有云选购...
你 发表评论:
欢迎- 一周热门
-
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
手机如何设置与显示准确时间的详细指南
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
FANUC 0i-TF数据备份方法(fanuc系统备份教程)
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)