服务器物理部署拓扑图,【网络】叶脊(Spine-Leaf)网络拓扑下全三层网络设计与实践(五)-物理服务器路由方案及配置...

5.1 本节目标

理解物理机的业务ip之间的通信过程;

了解如何在leaf交换机上配置业务ip的静态路由;

了解如何在物理机上配置业务ip及其他相关配置项;

5.2 拓扑结构

本节拓扑结构与上节相比没有变化,如下图:

a4c26d1e5885305701be709a3d33442f.png

5.3 物理机业务网络地址规划与配置

云平台各服务之间用于通信的ip地址称为业务ip地址,在spine

leaf网络中,我们为服务器分配业务ip地址,并配置在br0接口上,本系列文章研究spine

leaf网络。下面为四个物理机规划业务IP地址:

主机名 业务ip地址

devopsr01n01 10.10.10.21/32

devopsr01n02 10.10.10.22/32

devopsr02n01 10.10.10.23/32

devopsr02n02 10.10.10.24/32

按照上面的规划,给物理机配置业务ip,以devopsr01n01为例,进行如下配置:

brctl addbr br0

ip link set br0 up

ip address add 10.10.10.21/32 dev br0

其余物理机按例配置。

5.4 物理机业务地址路由方案与配置

5.4.1 在leaf交换机上配置路由

在leaf交换机上采用静态路由协议,路由方案的思路如下:

对于每个物理机业务ip地址,在一对leaf上配置静态路由;

通过检测路由下一跳ip的可达性,确定路由条目的有效性;

本文采用的是arista交换机来进行实验,因此提供arista交换机的配置方式,需要用到扩容模块PingCheck,点击查看安装方法,扩展模块安装完成后,进行下面的配置:

# 在leaf01上配置devopsr01n01的路由

ip route 10.10.10.21/32 Ethernet3 169.254.0.2 #

配置devopsr01n01的静态路由

daemon PingCheck3 #

此处因为devopsr01n01接在e3口,所以为了方便,这里名称写PingCheck3

exec

/usr/local/bin/PingCheck

option CHECKINTERVAL

value 1 # Ping间隔时间1s

option CONF_FAIL value

/mnt/flash/pingcheck/failed_3.conf # Ping失败时执行的操作,内容填“no ip route

10.10.10.21/32 Ethernet3 169.254.0.2”,

即删除到devopsr01n01的静态路由条目

option CONF_RECOVER value

/mnt/flash/pingcheck/recover_3.conf # Ping恢复时执行的操作,内容填“ip route

10.10.10.21/32 Ethernet3 169.254.0.2”,即添加到devopsr01n01的静态路由条目

option HOLDDOWN value

1

option HOLDUP value

1

option IPv4 value

169.254.0.2 #

Ping的目标地址,即到devopsr01n01的静态路由的下一跳地址,也就是devopsr01n01上与leaf01互联的网口的ip地址

option PINGCOUNT value

2

option PINGTIMEOUT value

2

option SOURCE value et3 #

指定Ping的出接口,即leaf01上与devopsr01n01互联的网口

no shutdown #

开始运行PingCheck

# 在leaf02上配置devopsr01n01的路由

ip route 10.10.10.21/32 Ethernet3 169.254.1.2 #

配置devopsr01n01的静态路由

daemon PingCheck3 #

此处因为devopsr01n01接在e3口,所以为了方便,这里名称写PingCheck3

exec

/usr/local/bin/PingCheck

option CHECKINTERVAL

value 1 # Ping间隔时间1s

option CONF_FAIL value

/mnt/flash/pingcheck/failed_3.conf # Ping失败时执行的操作,内容填“no ip route

10.10.10.21/32 Ethernet3 169.254.0.2”,

即删除到devopsr01n01的静态路由条目

option CONF_RECOVER value

/mnt/flash/pingcheck/recover_3.conf # Ping恢复时执行的操作,内容填“ip route

10.10.10.21/32 Ethernet3 169.254.0.2”,即添加到devopsr01n01的静态路由条目

option HOLDDOWN value

1

option HOLDUP value

1

option IPv4 value

169.254.1.2 #

Ping的目标地址,即到devopsr01n01的静态路由的下一跳地址,也就是devopsr01n01上与leaf01互联的网口的ip地址

option PINGCOUNT value

2

option PINGTIMEOUT value

2

option SOURCE value et3 #

指定Ping的出接口,即leaf01上与devopsr01n01互联的网口

no shutdown #

开始运行PingCheck

按例在leaf02上配置devopsr01n02的路由,在leaf03/04上配置devopsr02n01、devopsr02n02的路由。完成配置后,让我们来测试一下,是否达到了预期的效果:

在devopsr01n01的所有链路正常时,在leaf01, leaf02,

spine01上观察到devopsr01n01的路由条目:

# 在spine01上观察路由, 有两条等价路由,下一跳分别是leaf01和leaf02

spine01#sh ip route 10.10.10.21

B E 10.10.10.21/32 [200/0] via 169.254.0.249,

Ethernet1

via 169.254.1.249,

Ethernet2

# 在leaf01上观察路由,有一条静态路由,可从e3下联接口到达

leaf01#sh ip route 10.10.10.21

S 10.10.10.21/32 [1/0] via

169.254.0.2, Ethernet3

# 在leaf02上观察路由,有一条静态路由,可从e3下联接口到达

leaf02#sh ip route 10.10.10.21

S 10.10.10.21/32 [1/0] via

169.254.1.2, Ethernet3

在h11链路故障时(可通过关闭服务器网卡模拟),观察在leaf01, leaf02,

spine01上观察到devopsr01n01的路由条目:

# 在devopsr01n01上关闭eth1

ifconfig eth1 down

# 在spine上观察路由, 发现只剩一条路径可用,下一跳为leaf02

spine01#sh ip route 10.10.10.21

B E 10.10.10.21/32 [200/0] via 169.254.1.249,

Ethernet2

# 在leaf01上观察路由,

发现此时从leaf01无法从下联接口到达目标,从而选择从spine学到的bgp路由,经由spine到达目标

leaf01#sh ip route 10.10.10.21

B E 10.10.10.21/32 [200/0] via 169.254.0.250,

Ethernet1

via 169.254.0.254,

Ethernet2

# 在leaf02上观察路由,有一条静态路由,可从e3下联接口到达

leaf02#sh ip route 10.10.10.21

S 10.10.10.21/32 [1/0] via

169.254.1.2, Ethernet3

请模拟在h12链路故障时的情况,观察路由变化。

5.4.2 在物理机上配置路由

业务ip配置在br0上,而非物理网卡上,因此需开启内核转发功能:

sysctl -w net.ipv4.ip_forward=1

以devopsr01n01为例,流量经由eth0和eth1两个网口收发,可以达到提高带宽,链路冗余的作用,因此在服务器上的路由配置如下:

# 两个下一跳地址分别为物理机和对应的两个leaf相连的网口互联ip地址

ip route replace default src 10.10.10.21 nexthop via

169.254.0.1 nexthop via 169.254.1.1

配置完上述路由后,与在交换机上的PingCheck一样,服务器也需要某种机制来判断下一跳是否有效:

# 对eth0

eth1启用链路检测,当链路down时,使相应的路由失效,否则物理机可能将流量发往down的链路,从而发生网络故障

sysctl -w

net.ipv4.conf.eth0.ignore_routes_with_linkdown=1

sysctl -w

net.ipv4.conf.eth1.ignore_routes_with_linkdown=1

# 配置完这一条后可做如下测试,先查看本机路由条目, 发现默认路由有两条等价路由

root@devopsr01n01:~# ip r

default src 10.10.10.21

nexthop via 169.254.0.1 dev eth1 weight

1

nexthop via 169.254.1.1 dev eth0 weight

1

169.254.1.0/30 dev eth0 proto

kernel scope link src

169.254.1.2

# 然后关闭eth1接口

ifconfig eth1 down

# 然后再查看路由,发现eth1对应的路由条目失效

root@devopsr01n01:~# ip r

default src 10.10.10.21

nexthop via 169.254.0.1 dev eth1 weight 1

dead linkdown

nexthop via 169.254.1.1 dev eth0 weight

1

169.254.1.0/30 dev eth0 proto

kernel scope link src

169.254.1.2

(Optional)上述步骤完成后,物理机上的路由就算完成了,当然,还可以加上以下的参数,让系统根据ip地址和端口来计算hash,作为选择路由的依据:

sysctl -w net.ipv4.fib_multipath_hash_policy=1

请按照上面的步骤,为其余几台物理机也完成路由配置。

5.5 测试配置结果

从devopsr01n01上ping devopsr01n02, 能够连通,说明配置成功,

其他节点测试方法相同。

root@devopsr01n01:~# ping 10.10.10.22 -c 1

PING 10.10.10.22 (10.10.10.22) 56(84) bytes of data.

64 bytes from 10.10.10.22: icmp_seq=1 ttl=63 time=721 ms

--- 10.10.10.22 ping statistics ---

1 packets transmitted, 1 received, 0% packet loss, time

0ms

rtt min/avg/max/mdev = 721.175/721.175/721.175/0.000 ms

5.6 小结

本节主要讲解了在交换机和服务器上如何为业务ip配置等价多路径(ECMP)路由条目,以及判断路由条目有效性的机制,这很重要,因为这样的机制才使得各个设备总是能选择到正确的路由。接下来的章节,将介绍在spine

leaf网络中,虚拟机的路由机制。

附 :其他品牌交换机上的路由检测机制

本节中arista交换机使用了PingCheck这个扩展模块来实现路由检测,以判断路由条目的有效性,其他厂商的网络设备大都有内置的命令可以实现这一功能,下面用一组配置范例来对比说明arista和Cisco

Nexus 9K的配置。

如下配置为本节中leaf01上检测devopsr01n01业务ip路由有效性的一组配置

ip route 10.10.10.21/32 Ethernet3 169.254.0.2 #

配置devopsr01n01的静态路由

daemon PingCheck3 #

此处因为devopsr01n01接在e3口,所以为了方便,这里名称写PingCheck3

exec

/usr/local/bin/PingCheck

option CHECKINTERVAL

value 1 # Ping间隔时间1s

option CONF_FAIL value

/mnt/flash/pingcheck/failed_3.conf # Ping失败时执行的操作,内容填“no ip route

10.10.10.21/32 Ethernet3 169.254.0.2”,

即删除到devopsr01n01的静态路由条目

option CONF_RECOVER value

/mnt/flash/pingcheck/recover_3.conf # Ping恢复时执行的操作,内容填“ip route

10.10.10.21/32 Ethernet3 169.254.0.2”,即添加到devopsr01n01的静态路由条目

option HOLDDOWN value

1

option HOLDUP value

1

option IPv4 value

169.254.0.2 #

Ping的目标地址,即到devopsr01n01的静态路由的下一跳地址,也就是devopsr01n01上与leaf01互联的网口的ip地址

option PINGCOUNT value

2

option PINGTIMEOUT value

2

option SOURCE value et3 #

指定Ping的出接口,即leaf01上与devopsr01n01互联的网口

no shutdown #

开始运行PingCheck

在Cisco Nexus 9K上,对应上面配置的功能,应该作出如下一组配置

feature sla sender # 开启sla功能

ip sla 3 # 此处因为devopsr01n01接在e1/3口,所以为了方便,这里名称写sla 3

icmp-echo 169.254.0.2 source-interface

ethernet 1/3 #

Ping的目标地址,即到devopsr01n01的静态路由的下一跳地址,也就是devopsr01n01上与leaf01互联的网口的ip地址,以及指定Ping的出接口,即leaf01上与devopsr01n01互联的网口

threshold 500 # 阈值 500ms,

小于等于超时时间timeout值即可

timeout 500 # 超时时间500ms

frequency 1 # ping的频率,单位秒

ip sla schedule 3 life forever start-time now #

开始序号为3的sla检测,一直运行,立即开始

track 3 ip sla 3 # 配置track 3, 跟踪sla 3的状态

ip route 10.10.10.21 255.255.255.255 ethernet 1/3 169.254.0.2

track 3 # 配置到devopsr01n01业务ip的路由,以track 3的状态决定改路由的有效性

————————————————

版权声明:本文为CSDN博主「eponia」的原创文章,遵循 CC 4.0 BY-SA

版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/m0_37904728/article/details/100012269

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/359953.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

axios队列 vue_vue axios全攻略

不再继续维护vue-resource,并推荐大家使用 axios 开始,axios 被越来越多的人所了解。本来想在网上找找详细攻略,突然发现,axios 的官方文档本身就非常详细!!有这个还要什么自行车!!所…

linux内核模块简介

linux内核是一个整体是结构。因此向内核添加任何东西。或者删除某些功能 ,都十分困难。为了解决这个问题。引入了内核机制。从而可以动态的想内核中添加或者删除模块。模块不被编译在内核中,因而控制了内核的大小。然而模块一旦被插入内核,他就和内核其他部分一样。这样一来 就…

移动app显示远程服务器错误,KIS移动应用常见问题汇总

1、移动应用平台正式版登录后,变成试用版/已过期答:更新移动应用平台到最新版本V4.0.0.2,下载地址:http://dwz.cn/kis0268多次退出移动应用平台,直到变成正式版,重新启动移动应用。2、移动应用使用过程中提…

在@NamedQueries中枚举@NamedQuery

介绍 如果您是使用JPA的Java开发人员,则很可能在实体上声明了一个或多个NamedQuery对象。 要在类上声明NamedQuery ,必须使用查询名称及其JPQL对该类进行简单注释,例如: Entity NamedQuery(name "findAllProjects",q…

csv转json文件

今天因为需要帮一个同事的新闻内容录入为html, 每次手改不方便,所以就弄了个csv(excel)转json的c程序,然后再利用ejs把它渲染成网页,打开渲染好的网页再保存(不能保存源文件,不然还是空的),就可以把内容弄成一个html了…

探测服务器操作系统,探测服务器操作系统工具

探测服务器操作系统工具 内容精选换一换lib库获取方式不同,编译环境配置方法不同,下面分别介绍。根据Mind Studio安装服务器操作系统及架构与硬件环境是否相同,编译环境分为如下两种场景:若Mind Studio安装服务器操作系统及架构与…

Java Web App体系结构

我曾经利用Servlet,JSP,JAX-RS,Spring框架,Play框架,带有Facelets的JSF和一些Spark框架。 以我的拙见,所有这些解决方案都远非面向对象和优雅的。 它们都充满了静态方法,无法测试的数据结构和肮…

android listview使用自定义的adapter没有了OnItemClickListener事件解决办法

在使用listview的时用使用自定义的adapter的时候,如果你的item布局中包含有Button,Checkable继承来的所有控件,那么你将无法获取listview的onItemClickListener事件是由于Button,Checkable继承来的所有控件或默认获取焦点。解决办…

mysql用的是标准sql_标准SQL语言的用法_MySQL

SQL语言是目前最通用的关系数据库语言。ANSI SQL是指由美国国家标准局(ANSI)的数据库委员会制定的标准SQL语言,多数关系数据库产品支持标准SQL语言,但是它们也往往有各自的SQL方言。在分层的软件结构中,关系数据库位于最底层,它的…

三星有网络显示无网络连接到服务器,三星s5296连接了网络为什么不能用 看完这些原因就知道了...

1、无线网络本身有问题:如果手机连接上WiFi但却上不了网,首先要检查一下无线网络本身是否存在问题。这时候可以检查一下其他联网设备是否可以正常上网,如果可以的话,说明无线网络网络本身是没有问题的。如果其他联网设备也不能上网…

Mono for Android 篇二 使用Spinner 实现下拉列表读取Browser.BookmarksUri

http://www.cnblogs.com/ivanyb/archive/2013/03/05/2944818.html 1、首先在VS2010里面创建一个Android Application 简单说明一下解决方案中各个文件的作用: AndroidManifest.xml:项目环境配置文件,指明了使用Android SDK的版本,…

mysql不复制数据_windows mysql不停止服务复制数据

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里云数据库专家保驾护航,为用户…

C++ 中的类模板

原文连接:http://see.xidian.edu.cn/cpp/biancheng/view/213.html 有时,有两个或多个类,其功能是相同的,仅仅是数据类型不同,如下面语句声明了一个类:class Compare_int{ public : Compare(int a,int b…

学生机房管理服务器系统设计,广东工业大学数据库课程设计机房管理系统设计...

《广东工业大学数据库课程设计机房管理系统设计》由会员分享,可在线阅读,更多相关《广东工业大学数据库课程设计机房管理系统设计(27页珍藏版)》请在人人文库网上搜索。1、课程设计个人报告课程名称 数据库应用与设计 _题目名称 机房管理系统 _学生学院 …

mysql磁盘临时表清理_mysql 创建大量磁盘临时表

发现 mysql 中创建的临时表基本都是磁盘临时表,对此进行排查。最后为临时表机制说明。通过查看 mysql 状态变量,看到创建的临时表基本都是磁盘临时表。查看临时表配置,默认配置 16M,配置并没有问题。创建两个表,做一个…

吃鸡服务器8月10日维护,《黑潮之上》2021年8月10日不停服维护公告

在黑潮之上手游中2021年8月10日更新了哪些有趣的内容呢?想了解本次更新情况如何的小伙伴们,接下来就让我们一起来看一下吧!各位接触者:为了提供良好的游戏体验,保证服务器稳定运行,《黑潮之上》将于2021年8月10日早5:0…

资格赛:题目1:同构

时间限制:2000ms单点时限:1000ms内存限制:256MB描述 给定2个树A和B,保证A的节点个数>B的节点个数。 现在你需要对树A的边进行二染色。 一个好的染色方案,指不存在一个树A中的连通块,同时满足以下2个条件 1. 其中只有同色的边 2. 和B同构。…

如何使用Java 8 FlatMap JDBC ResultSet?

您还不喜欢机能吗? 这样标题可能不会引起您的共鸣-但文章会! 相信我。 本质上,我们想要这样: ------------------ | col1 | col2 | col3 | ------------------ | A | B | C | row 1 | D | E | F | row 2 | G …

java 获取mysql链接_Java中如何获取mysql连接的3种方法总结

前言本文主要来说说三种 Java 中获取 mysql 连接的方式,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:第一种:传统的连接方式;第二种:读取配置文件方式;第三种&…

Netty writeAndFlush() 流程与异步

Netty writeAndFlush()方法分为两步, 先 write 再 flush Overridepublic ChannelFuture writeAndFlush(Object msg, ChannelPromise promise) {DefaultChannelHandlerContext next;next findContextOutbound(MASK_WRITE);ReferenceCountUtil.touch(msg, next);next.invoker.in…