配置IPv4/IPv6 BGP双栈动态路由

2024-01-20 22:38

本文主要是介绍配置IPv4/IPv6 BGP双栈动态路由,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

IPv6 BGP简介

BGP-4 是一种用于不同自治系统之间的动态路由协议,只能管理 IPv4 的路由信息。对于使用其它网络层协议(如 IPv6 等)的应用,在跨自治系统传播时就受到一定限制。

为了提供对多种网络层协议的支持,IETF 对 BGP-4 进行了扩展,其中对于 IPv6 协议的支持就形成了IPv6 BGP。IPv6 BGP 是利用 BGP 的多协议扩展属性,来达到在 IPv6 网络中应用的目的,BGP-4 原有的消息机制和路由机制并没有改变。

BGP-4中与IPv4网络层协议相关的信息由Update消息携带,这些信息是:NLRI、路径属性中的NEXT_HOP、路径属性中的AGGREGATOR(该属性中包含形成聚合路由的BGP发言者的IP地址和Router ID)。

为实现对IPv6的支持,IPv6 BGP对Update消息的NLRI和NEXT_HOP属性信息进行了扩展:

  1. 引入两个新的路径属性MP_REACH_NLRI和MP_UNREACH_NLRI代替了BGP-4的NLRI字段,以提供对IPv6地址的支持。
  2. 下一跳信息支持对IPv6地址的支持,不仅支持全球单播IPv6地址还可支持本地链路IPv6地址。由于下一跳信息只是对可达路由进行通告,因此将此信息通过MP_REACH_NLRI属性携带,而不是在NEXT_HOP属性中携带。

此外,IPv6 BGP与BGP-4的不同点还有:BGP-4中的Router ID可以手工配置,也可以采用接口的IPv4地址。IPv6 BGP的Router ID与BGP-4共用一个,仍然采用IPv4地址作为IPv6 BGP的Router ID。但如果在纯IPv6环境,则需要手工配置,且仍用IPv4地址形式标识。

测试场景

配置要求

本文测试的BGP环境均在一个AS域中。

本文测试场景是使用一台quagga通过openflow交换机与H3C物理交换机之间的IPv4-IPv6 BGP双栈测试;

组网图

在这里插入图片描述

测试环境配置及测试

静态路由配置及测试

静态路由配置

  • 虚拟机配置
    首先需要根据测试组网配置虚拟机192.168.6.250端口ens7的ipv6地址以及路由信息。
  1. ens7网卡上添加H3C交换机router-id的路由
    ip route add 10.0.0.1/32 via 172.18.0.1
  2. ens7网卡上添加ipv6地址
    ifconfig ens7 inet6 add 2001:db8:3::250/64
  3. 配置到192.168.6.201的ipv6路由
    route -A inet6 add 2001:db8:3::3/64 dev ens7
  • 物理机配置
  1. 添加H3C交换机router-id的路由
    ip route add 10.0.0.1/32 via 172.18.0.1
  2. 添加到虚拟机router-id的路由
    ip route add 6.6.6.6/32 via 172.18.0.250
  3. br1网桥上添加ipv6地址
    ifconfig br1 inet6 add 2001:db8:3::1/64
  4. 配置到192.168.6.201的ipv6路由
    route -A inet6 add 2001:db8:3::3/64 dev br1
  • H3C 192.168.6.201配置
  1. 在vlan102上面配置ipv6地址
    [S5560.6.201-Vlan-interface102]ipv6 address 2001:DB8:3::3/64
  2. 配置ipv6的路由
    [S5560.6.201]ipv6 route-static 2001:DB8:3::250 64 Vlan-interface 102 2001:db8:3::1
  3. 配置到虚拟机router-id的路由
    [S5560.6.201]ip route-static 6.6.6.6 255.255.255.255 172.18.0.250

静态路由测试

  • 查看虚拟机的路由表
  1. Ipv4路由表
    这里写图片描述
  2. Ipv6路由表
    这里写图片描述
  • 查看H3C192.168.6.201的路由表
  1. Ipv4路由表
    这里写图片描述
    这里写图片描述
  2. Ipv6路由表
    这里写图片描述
  • 虚拟机与H3C交换机之间互ping
  1. 在虚拟机上面ping H3C
    这里写图片描述
    这里写图片描述
  2. 在H3C上面ping虚拟机
    这里写图片描述

配置BGP双栈

虚拟机bgp的配置

这里写图片描述

H3C的bgp配置

配置注意事项:

  • 为了防止端口状态不稳定引起路由震荡,本举例使用LoopBack接口来创建IBGP对等体。
  • 使用LoopBack接口创建IBGP对等体时,因为LoopBack接口不是两对等体实际连接的接口,所以,必须使用peer connect-interface命令将LoopBack接口配置为BGP连接的源接口。
  • EBGP邻居关系的两台路由器,处于不同的AS域,对端的LoopBack接口一般路由不可达,所以一般使用直连地址建立EBGP邻居。
  • H3C配置的network一定是有效路由,不然quagga学习不到。
  • Ipv6邻居不需要配置loopback 0 地址。
    这里写图片描述

测试BGP双栈

测试IPv4 BGP协议栈

  1. 在quagga上面查看bgp邻居信息
    bgpd# show bgp ipv4 unicast summary
    (quagga的实现有点小问题,查看ipv4 bgp信息时,ipv6的也出现了)
    这里写图片描述
    bgpd# show bgp neighbors 10.0.0.1
    这里写图片描述
  2. 在H3C上面查看bgp邻居信息
    [S5560.6.201-bgp]display bgp peer ipv4
    这里写图片描述
  3. 测试双方是否能动态学习对方的network
    参照3.2节ipv4中的network配置,分别查看quagga和H3C的路由学习情况
  • Quagga的路由学习情况
    bgpd# show bgp ipv4 unicast neighbors 10.0.0.1 routes
    这里写图片描述
  • H3C的路由学习情况
    [S5560.6.201-bgp]dis bgp routing-table ipv4
    这里写图片描述

测试Ipv6 BGP协议栈

  1. 在quagga上面查看bgp邻居信息
    bgpd# show bgp ipv6 unicast summary
    这里写图片描述
    bgpd# show bgp neighbors 2001:db8:3::3
    这里写图片描述
    (由于刚开始配置有问题,导致quagga发送了许多open协议,而H3C没有回应,所以才看到quagga sent的open消息非常多)
  2. 在H3C上面查看bgp邻居信息
    [S5560.6.201-bgp]display bgp peer ipv6
    这里写图片描述
  3. 测试双方是否能动态学习对方的network
  • Quagga的路由学习情况
    bgpd# show bgp ipv6 unicast neighbors 2001:db8:3::3 routes
    这里写图片描述
  • H3C的路由学习情况
    [S5560.6.201-bgp]dis bgp routing-table ipv6
    这里写图片描述

这篇关于配置IPv4/IPv6 BGP双栈动态路由的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d