### 单臂路由:利用传统路由器的桥接功能
单臂路由是一种利用传统路由器实现不同VLAN间通信的技术。在这种配置中,路由器的一个物理接口被划分为多个虚拟子接口,每个子接口对应一个VLAN。通过配置路由器的路由表,可以实现不同VLAN间的数据转发。
以一个简单的网络拓扑为例,假设有一个路由器连接到两个交换机,每个交换机连接两个不同的VLAN。通过在路由器上配置相应的子接口和路由表,可以实现两个VLAN间的通信。这种方法简单易行,适合小型网络环境。
### 三层交换机:硬件实现的快速转发
三层交换机是专门为高速网络转发设计的设备。与传统的路由器不同,三层交换机使用硬件来实现数据包的转发,因此在性能上有着明显的优势。三层交换机通常具有数百万包每秒(pps)的吞吐量,远远超过传统路由器的10kpps至1Mpps。
在三层交换机上实现VLAN间通信的过程类似于单臂路由。首先,需要为每个VLAN创建一个虚拟接口,并为其分配相应的ip地址。然后,通过配置路由表,实现不同VLAN间的数据转发。这种方法适用于大型网络环境,尤其是需要高速数据转发的场景。
### 如何选择合适的技术?
在选择实现VLAN间通信的技术时,需要考虑网络规模、性能需求和成本等因素。对于小型网络,单臂路由可能是更合适的选择,因为它简单易行,成本相对较低。然而,对于大型网络,尤其是需要高速数据转发的场景,三层交换机无疑是更好的选择。三层交换机的高速转发能力和扩展性使其成为大型网络的首选。
### 总结
实现VLAN间通信是网络设计中的一项重要任务。单臂路由和三层交换机是两种常用的技术。单臂路由适用于小型网络,而三层交换机适用于大型网络。在选择合适的技术时,需要综合考虑网络规模、性能需求和成本等因素。通过合理配置,可以确保网络的高效运行,并满足不同业务的需求。
昨天我们提到1000路大型网络监控如何分配ip地址?, 有朋友问到,vlan间需要什么才能通信呢?如何让不同vlan之间通信,我们通常提到了,vlan间通信需要三层交换机,那么不用三层交换机能不能通信呢?其实不同VLAN之间相互通信的两种方式,单臂路由、三层交换机,它们分别如何配置呢?哪一种好呢?
今天我们来看下,这两种方式是如何来实现vlan间的通信。
本篇文章要从三个问题开始说起?
1、实现vlan间的通信有哪些方式?
2、它们如何实现?如何配置?
3、它们有什么不同之处?哪一种好?
一、实现不同vlan间的通信有哪些?
我们知道要实现不同vlan间通信,就必须需要有路由功能,单臂路由的实现方式,其实就是普通二层交换机加路由器,从而实现不同vlan间的可以互相通信。
那为什么三层交换机不用路由器?因为三层交换机本身有路由功能,所以不用其它路由就可以实现vlan间的通信。
因此:
不 同VLAN之间相互通信的两种方式(单臂路由、三层交换机),我们来看下他们的组网拓扑图,对网络有了解的朋友,就能看出他们的区别。
1、通过单臂路由实现不同VLAN之间的通信,如下图:
2、通过三层交换路由功能实现不同VLAN之间的通信: 如下图
当然看这两个拓扑图很多朋友可能不是很清楚,那么下面我们来通过交换机配置来详细了解,如何用两种方式分别实现不同vlan间通信。
二、单臂路由实现不同vlan互通
拓扑图如下:
上面说了,单臂路由组网是由普通交换机与路由器组成,所以我们在配置时,要配置交换机与路由。
1、 交换机SW3的具体配置(主要配置vlan和Trunk接口)
第一步: 在SW3上创建vlan100、vlan200、vlan300,名称依次为caiwu、xiaoshou、gongcheng。(创建vlan既可以在vlandatabase中,也可以在全局模式下配置,本实验是在vlan database中配置的)。
第二步: 在全局模式下,
将f0/1 – 5号端口划分到vlan 100中,
f0/6– 10口划分到vlan 200中,
f0/11 – 15号端口划分到vlan 300中,
并全部配置成Access模式。
第三步: 使用show vlan显示SW3的vlan配置信息,可以看出配置正确)
第四步: 交换机如果通过路由器实现VLAN之间的通信,需要将连接交换机的端口配置成trunk模式,只有trunk线路才能使vlan通过。
2、 路由器R2的具体配置(通过配置路由器子接口封装之后作为每一个vlan的网关)
第一步:在路由器(R2)与交换机(SW3)的端口上配置子接口,每个子接口的IP地址是每个VLAN的网关地址(也可以理解为下一跳地址),并在子接口上封装802.1Q协议(交换机通用封装模式,用命令encapsulation dot1q 封装),如下所示:
第二步: 将PC5和PC6分别连接到交换机SW3的f0/6和f0/1上,然后配置PC5的IP地址为192.168.2.1/24,网关为192.168.2.254。PC6的IP地址为192.168.1.1,网关为192.168.1.254。然后用PC5 ping PC6,看是否能ping通。
pc5与pc6处于不同的vlan,如上所示,他们已能够互通,所以不同vlan间已实现互通。
三、三层交换机实现不同vlan间互通
三层交换机的配置我们前面曾多次提到,例子有很多,这里面我们就举个稍显复杂些的例子来举例了,这也是项目中经常会遇到的典型案例。
拓扑图如下:
为了让大家能够更详细的看到代码的注释,我们就不截图,直接发配置代码。
一、【实验目的】
1、同一VLAN里的计算机系统能跨交换机相互通信。
2、不同VLAN里的计算机系统也可以相互通信。
3、各vlan信息如下:
vlan10: 192.168.10.1/24
vlan20: 192.168.20.1/24
vlan30: 192.168.30.1/24
4、各pc ip地址及网关如下:
pc机 ip地址 网关
pc1 192.168.10.2/24 192.168.10.1
pc2 192.168.20.2/24 192.168.20.1
pc3 192.168.10.3/24 192.168.10.1
pc4 192.168.20.3/24 192.168.20.1
pc5 192.168.30.2/24 192.168.30.1
pc6 192.168.20.4/24 192.168.20.1
pc7 192.168.30.3/24 192.168.30.1
二、【配置步骤】
1、交换机s0的配置如下:
Switch> en //进入特权模式
Switch(config)#vlan 10 //创建vlan10
Switch(config-vlan)#vlan 20 //创建vlan20
Enter configuration commands, one perline. End with CNTL/Z.
Switch(config)#int fa0/2 //进入端口0/2
Switch(config-if)#switchport access vlan 10 //把端口 0/2划分给vlan10
Switch(config-if)#exit //退出 端口0/2
Switch(config)#int fa0/3 //进入端口0/3
Switch(config-if)#switchport access vlan 20 //把端口0/3划分给vlan20
Switch(config-if)#exit //退出端口0/3
Switch(config)#int fa0/1 //进入端口0/1
Switch(config-if)#switchport mode trunk //端口模式为trunk
Switch(config-if)#
小结:把交换机S0的下面的端口各pc分配各自的vlan,然后把fa0/1口设为trunk,因为交换机之间设置了trunk接口,使得不同vlan之间能够通过其他的交换机!
2、交换机s1的配置如下:
Switch>en
Switch#conf t
Enter configuration commands, one perline. End with CNTL/Z.
Switch(config)#vlan 10
Switch(config-vlan)#exit
Switch(config)#vlan 20
Switch(config-vlan)#vlan 30
Switch(config-vlan)#exit
Switch(config)#int f0/2
Switch(config-if)#switchport access vlan 10
Switch(config-if)#exit
Switch(config)#int f0/3
Switch(config-if)#switchport access vlan 20
Switch(config-if)#exit
Switch(config)#int f0/4
Switch(config-if)#switchport access vlan 30
Switch(config-if)#exit
Switch(config)#int f0/1
Switch(config-if)#switchport mode trunk //端口模式为trunk
交换机s1的配置如s0的基本差不多,代码都一样。
3、交换机s2的配置如下:
Switch>en
Switch#conf t
Enter configuration commands, one perline. End with CNTL/Z.
Switch(config)#vlan 20
Switch(config-vlan)#vlan 30
Switch(config-vlan)#exit
Switch(config)#int fa0/2
Switch(config-if)#switchport access vlan 20
Switch(config-if)#exit
Switch(config)#int fa0/3
Switch(config-if)#switchport access vlan 30
Switch(config-if)#exit
Switch(config)#int fa0/1
Switch(config-if)#switchport mode trunk
交换机s2的配置如s0、s1的基础差不多,把相应的端口划分到相应的vlan中,没有出现什么新代码。
4、三层交换机3560的配置如下:
Switch>en //进入特权模式
Switch#conf t //进入配置模式
Switch(config)#vlan 10 //创建vlan10
Switch(config-vlan)#vlan 20 //创建vlan20
Switch(config-vlan)#vlan 30 //创建vlan10
Switch(config-vlan)#exit //返回上一级
Switch(config)#int vlan 10 //进入vlan10
Switch(config-if)#ip address 192.168.10.1 255.255.255.0 //给vlan 10添加ip地址及子网掩码
Switch(config-if)#no shutdown //开启端口
Switch(config-if)#exit //退回 上一极
Switch(config)#int vlan 20 //进入vlan20
Switch(config-if)#ip address 192.168.20.1 255.255.255.0 //给vlan 20添加ip地址及子网掩码
Switch(config-if)#no shutdown //开启端口
Switch(config-if)#exit //退回上一级
Switch(config)#int vlan 30 //进入vlan30
Switch(config-if)#ip address 192.168.30.1 255.255.255.0 //给vlan 20添加ip地址及子网掩码
Switch(config-if)#no shutdown //开启端口
Switch(config-if)#exit //返回上一级
Switch(config)#int range fa0/2-4 //进入2-4端口
Switch(config-if-range)#switchport mode trunk //端口模式为trunk
Switch#show ip route //显示IP路由
那么这样就配置完成了。
三、总结
从试验过程中可以看出实现不同VLAN之间的两种方式,一个是通过单臂路由实现,另一个是通过三层交换的路由功能实现的,可以说不同VLAN之间的通信必须通过路由功能才能实现通信。
其次,不同网段之间都需要配置下一跳地址(网关)才能通信。那么什么时候用单臂路由,什么时候选择三层交换呢。单臂路由是不具有扩展性的,为什么这么说呢,如果VLAN的数量不断增加,流经路由器与交换机之间链路的流量也变得非常大,这时,这条链路也就成为了整个网络的瓶颈,即使你网络的带宽再快,也是如此。
因此,当网络不断增大,划分的VLAN不断增多的时候,就需要配置三层交换机的路由功能,实现不同VLAN之间的通信(三层交换机的数据表的吞吐量通常为数百万pps,而传统路由器的吞吐量只有10kpps~1Mpps,其次三层交换机是通过硬件来交换和路由选择数据包的,吞吐量当然大了,甚至接近于线速。而路由器只是通过虚拟子接口来交换和路由选择数据包的,不是硬件实施的,吞吐量也就变的小了。
总之一句话:三层交换技术在第三层实现了数据包的高速转发,从而解决了传统路由器低速、负责所造成的网络瓶颈问题。