Packet Tracer 是由Cisco公司发布的一个辅助学习工具,为学习思科网络课程的初学者去设计、配置、排除网络故障提供了网络模拟环境。用户可以在软件的图形用户界面上直接使用拖曳方法建立网络拓扑,并可提供数据包在网络中行进的详细处理过程,观察网络实时运行情况。可以学习IOS的配置、锻炼故障排查能力。
将两台 PC 直接连接构成一个网络。注意:直接连接需使用交叉线。
进行两台 PC 的基本网络配置,只需要配置 IP 地址即可,然后相互 ping 通即成功。
配置过程:
问题: 1、PC0能否 ping 通 PC1、PC2、PC3 ?
答:PC0能ping通PC1,但不能ping通PC2、PC3。
2、PC3能否 ping 通 PC0、PC1、PC2?为什么?
答:PC3能ping通PC2,但不能ping通PC0、PC1。
3、将 4 台 PC 的掩码都改为 255.255.0.0 ,它们相互能 ping 通吗?为什么?
答:相互之间能ping通。
如果掩码为255.255.255.0,PC0、PC1和PC2、PC3不是同一局域网,他们之间不能互通。
而掩码改为255.255.0.0,他们之间属于同一局域网下,可以互通。
4、使用二层交换机连接的网络需要配置网关吗?为什么?
答:需要。在二层交换机中,配置网关尤为重要,因为其与相连的自bai治系统可以向核心系统通告可达信息。
试一试:
集线器 Hub 是工作在物理层的多接口设备,它与交换机的区别是什么?
答:集线器Hub是工作在物理层,而交换机则是工作在物理层和数据链路层。两种工作的区域不同。
二层交换机是一种即插即用的多接口设备,它对于收到的帧有 3 种处理方式:广播、转发和丢弃(请弄清楚何时进行何种操作)。那么,要转发成功,则交换机中必须要有接口地址列表即 MAC 表,该表是交换机通过学习自动得到的!
仍然构建上图的拓扑结构,并配置各计算机的 IP 在同一个一个子网,使用工具栏中的放大镜点击某交换机如左边的 Switch3,选择 MAC Table,可以看到最初交换机的 MAC 表是空的,也即它不知道该怎样转发帧(那么它将如何处理?),用 PC0 访问(ping)PC1 后,再查看该交换机的 MAC 表,现在有相应的记录,请思考如何得来。随着网络通信的增加,各交换机都将生成自己完整的 MAC 表,此时交换机的交换速度就是最快的!
秘籍
你还可以使用 CPT 的 Simulation 模式即模拟方式进一步看清楚这个过程!
交换机在目的地址未知或接收到广播帧时是要进行广播的。如果交换机之间存在回路/环路,那么就会产生广播循环风暴,从而严重影响网络性能。
而交换机中运行的 STP 协议能避免交换机之间发生广播循环风暴。
只使用交换机,构建如下拓扑:
这是初始时的状态。我们可以看到交换机之间有回路,这会造成广播帧循环传送即形成广播风暴,严重影响网络性能。
随后,交换机将自动通过生成树协议(STP)对多余的线路进行自动阻塞(Blocking),以形成一棵以 Switch4 为根(具体哪个是根交换机有相关的策略)的具有唯一路径树即生成树!
经过一段时间,随着 STP 协议成功构建了生成树后,Switch5 的两个接口当前物理上是连接的,但逻辑上是不通的,处于Blocking状态(桔色)如下图所示:
在网络运行期间,假设某个时候 Switch3与 Switch4 之间的物理连接出现问题(将 Switch3 与 Switch4 的连线剪掉),则该生成树将自动发生变化。Switch5 上方先前 Blocking 的那个接口现在活动了(绿色),但下方那个接口仍处于 Blocking 状态(桔色)。如下图所示:
注意
交换机的 STP 协议即生成树协议始终自动保证交换机之间不会出现回路,从而形成广播风暴。
我们模拟重庆交通大学和重庆大学两个学校的连接,构建如下拓扑:
当连接laptop和重庆交通大学路由器时连不上
默认的2621XM路由器端口不够用,我们需要在设备互连前要添加所需的路由器模块。我们为 Router 0添加NM-4E模块
可以连接,接着在配置里启用端口即可
说明一
交通大学与重庆大学显然是两个不同的子网。在不同子网间通信需通过路由器。
路由器的每个接口下至少是一个子网,图中我们简单的规划了 3 个子网:
左边路由器是交通大学的,其下使用交换机连接交通大学的网络,分配网络号 192.168.1.0/24,该路由器接口也是交通大学网络的网关,分配 IP 为 192.168.1.1
右边路由器是重庆大学的,其下使用交换机连接重庆大学的网络,分配网络号 192.168.3.0/24,该路由器接口也是重庆大学网络的网关,分配 IP 为 192.168.3.1
两个路由器之间使用广域网接口相连,也是一个子网,分配网络号 192.168.2.0/24
注意
在我们的实验中可不进行如下的配置,但在现实中为了安全,以下的登录及特权密码等配置是必须的,否则每个人都可操作你的路由器或交换机!
Router>en // 从普通模式进入特权模式
Router#conf t // 进入全局配置模式
Router(config)#interface FastEthernet0/0
Router(config-if)#ip address 192.168.1.1 255.255.255.0
Router(config-if)#no shutdown
Router(config-if)#exit
Router(config)#line vty 0 4 //可支持0-4共5个终端同时登录
Router(config-line)#password xianlu // 远程登录密码
Router(config-line)#login
Router(config-line)#exit
Router(config)#enable password xianlu // 特权模式密码 Router(config)#^Z //退出
拓扑图中路由器各接口配置数据如下:
交通大学 Router0 以太网口 192.168.1.1 255.255.255.0 交通大学 Router0 广域网口
192.168.2.1 255.255.255.0 重庆大学 Router1 以太网口 192.168.3.1 255.255.255.0 重庆大学 Router1 广域网口 192.168.2.2 255.255.255.0
拓扑图中各 PC 配置数据如下:
交通大学 PC6 192.168.1.2 255.255.255.0 192.168.1.1 交通大学 PC7 192.168.1.3
255.255.255.0 192.168.1.1 重庆大学 PC8 192.168.3.2 255.255.255.0 192.168.3.1 重庆大学 PC9 192.168.3.3 255.255.255.0 192.168.3.1
交通大学路由器基本配置如下:
以太网口:
Router>enable // 从普通模式进入特权模式 Router#configure terminal // 进入全局配置模式
Router(config)#interface f0/0 // 进入配置以太网口模式 Router(config-if)#ip
address 192.168.1.1 255.255.255.0 // 配置该接口的 IP Router(config-if)#no
shutdown // 激活接口 Router(config-if)#^z // 直接退到特权模式 Router#
广域网口:
Router>en // 从普通模式进入特权模式 Router#conf t // 进入全局配置模式 Router(config)#int
s0/0 // 进入配置广域网口模式 Router(config-if)#ip address192.168.2.1
255.255.255.0 //配置该接口的 IP Router(config-if)#clock rate 64000 // 其为 DCE 端,配置时钟频率 Router(config-if)#no shutdown // 激活接口 Router(config-if)#^z //
直接退到特权模式 Router#
重庆大学路由器基本配置如下:
以太网口:
Router>en // 从普通模式进入特权模式
Router#conf t // 进入全局配置模式
Router(config)#int f0/0 // 进入配置以太网口模式
Router(config-if)#ip address
192.168.3.1 255.255.255.0 // 配置该接口的 IP
Router(config-if)#no shutdown // 激活接口
Router(config-if)#^z // 直接退到特权模式 Router#
广域网口:
Router>en // 从普通模式进入特权模式
Router#conf t // 进入全局配置模式
Router(config)#int s0/0 // 进入配置广域网口模式
Router(config-if)#ip address192.168.2.2 255.255.255.0 //配置该接口的 IP
Router(config-if)#no shutdown // 激活接口
Router(config-if)#^z // 直接退到特权模式
Router#
至此,路由器基本的配置完成。请按照上面 PC 配置表继续配置各个 PC 。
问题 现在交通大学内的各 PC 及网关相互能 ping 通,重庆大学也类似。但不能从交大的 PC ping 通重大的
PC,反之亦然,也即不能跨子网。为什么?
答:在路由表中并没能够到达对方的路由路径,所以无法ping通。
静态路由是非自适应性路由协议,是由网络管理人员手动配置的,不能够根据网络拓扑的变化而改变。 因此,静态路由简单高效,适用于结构非常简单的网络。
在当前这个简单的拓扑结构中我们可以使用静态路由,即直接告诉路由器到某网络该怎么走即可。
在前述路由器基本配置成功的情况下使用以下命令进行静态路由协议的配置:
交通大学路由器静态路由配置:
Router>en // 从普通模式进入特权模式 Router#conf t // 进入全局配置模式
Router(config)#ip route 192.168.3.0 255.255.255.0 192.168.2.2 //
告诉交通大学路由器到 192.168.3.0 这个网络的下一跳是 192.168.2.2 Router(config)#exit
//退到特权模式 Router#show ip route //查看路由表
重庆大学路由器静态路由配置:
Router>en // 从普通模式进入特权模式 Router#conf t // 进入全局配置模式
Router(config)#ip route 192.168.1.0 255.255.255.0 192.168.2.1 //
告诉重庆大学路由器到 192.168.1.0 这个网络的下一跳是 192.168.2.1 Router(config)#exit
//退到特权模式 Router#show ip route //查看路由表
查看路由表你可看到标记为 S 的一条路由,S 表示 Static 。
至此,这些 PC 能全部相互 ping 通!
在实际网络中(如我校的网络),你可看到路由器一般位于网络的边界,而内部几乎全部使用交换机连接。
前面我们分析过,交换机连接的是同一个子网! 显然,在这样一个大型规模的子网中进行广播甚至产生广播风暴将严重影响网络性能甚至瘫痪。
另外我们也已经知道,其实学校是划分了 N 多个子网的,那么这些交换机连接的就绝不是一个子网!这样矛盾的事情该如何解释呢?我们实际上使用了支持 VLAN 的交换机!而前述的交换机只是普通的 2 层交换机(或者我们把它当作 2 层交换机在使用。
VLAN(Virtual Local Area Network)即虚拟局域网。通过划分 VLAN,我们可以把一个物理网络划分为多个逻辑网段即多个子网。
划分 VLAN 后可以杜绝网络广播风暴,增强网络的安全性,便于进行统一管理等。
在 CPT 中构建如下图所示拓扑:
Cisco 2960 交换机是支持 VLAN 的交换机,共有 24 个 100M 和 2 个 1000M 以太网口。默认所有的接口都在 VLAN 1 中,故此时连接上来的计算机都处于同一 VLAN,可以进行通信。
下面我们就该交换机的 24 个 100M 接口分为 3 个部分,划分到 3 个不同的 VLAN 中,id 号分别设为 10、20、30,且设置别名(computer、communication、electronic)以利于区分和管理。
交换机 VLAN 配置:
Switch>en
Switch#conf t
Switch(config)#vlan 10 // 创建 id 为 10 的 VLAN(缺省的,交换机所有接口都属于VLAN 1,不能使用)
Switch(config-vlan)#name computer // 设置 VLAN 的别名
Switch(config-vlan)#exit
Switch(config)#int vlan 10 // 该 VLAN 为一个子网,设置其 IP,作为该子网网关
Switch(config-if)#ip address 192.168.0.1 255.255.255.0
Switch(config-if)#exit
Switch(config)#vlan 20 // 创建 id 为 20 的 VLAN
Switch(config-vlan)#name communication //设置别名
Switch(config-vlan)#exit
Switch(config)#int vlan 20
Switch(config-if)#ip addr 192.168.1.1 255.255.255.0
Switch(config-if)#exit
Switch(config)#vlan 30 // 创建 id 为 20 的 VLAN
Switch(config-vlan)#name electronic // 设置别名
Switch(config-vlan)#exit
Switch(config)#int vlan 30
Switch(config-if)#ip add 192.168.2.1 255.255.255.0
Switch(config-if)#exit
Switch(config)#int range f0/1-8 // 成组配置接口(1-8)
Switch(config-if-range)#switchport mode access // 设置为存取模式
Switch(config-if-range)#switchport access vlan 10 // 划归到 VLAN 10 中
Switch(config-if-range)#exit
Switch(config)#int range f0/9-16
Switch(config-if-range)#switchport mode access
Switch(config-if-range)#switchport access vlan 20
Switch(config-if-range)#exit
Switch(config)#int range f0/17-24
Switch(config-if-range)#switchport mode access
Switch(config-if-range)#switchport access vlan 30
Switch(config-if-range)#^Z
Switch#show vlan // 查看 VLAN 的划分情况
至此,在该交换机上我们就划分了 3 个 VLAN(不包括缺省的 VLAN 1)。
各 VLAN 下 PC 的网络配置及连接的交换机接口如下表(分别对应我的pc8到pc14):
此时可以使用 ping 命令进行测试,你会发现只有在同一 VLAN 中的 PC 才能通信,且广播也局限于该 VLAN。
pc8 ping pc14,ping不通
pc8 ping pc9,ping通了
思考
分析一下当前为何不同 VLAN 中的 PC 不能通信?网关在此起什么作用?我们的网关又在何处?如何发起广播测试?
答:因为vlan划分了网络,同一个vlan中的端口可以不通过路由器直接通信,而不同vlan之间则需要路由器进行路由。网关在此起到的作用时进行协议转换。如果要发起广播测试,那么就需要三层设备。
前一个实验我们在交换机上进行了 VLAN 的规划和划分。但在实际应用中,我们绝不允许在这些支持VLAN的交换机上进行随意的 VLAN 划分,如此将造成管理混乱!VLAN的划分必须得到统一的规划和管理,这就需要 VTP 协议。
VTP(VLAN Trunk Protocol)即 VLAN 中继协议。VTP 通过 ISL 帧或 Cisco 私有 DTP 帧(可查阅相关资料了解)保持 VLAN 配置统一性,也被称为虚拟局域网干道协议,它是思科私有协议。 VTP 统一管理、增加、删除、调整VLAN,自动地将信息向网络中其它的交换机广播。
此外,VTP 减小了那些可能导致安全问题的配置,只要在 VTP Server 做相应设置,VTP Client 会自动学习 VTP Server 上的 VLAN 信息。
注意:
作为干线,两个 2960 交换机和核心的 3560 交换机应该使用 Gbit 口相连。这虽然不是必须,但现实中这样连接性能最好。
3560 交换机是网络中的核心交换机,我们将其作为 VTP Server,VTP 域及 VLAN 将在其上创建和管理。
两个 2960 交换机是是局域网中的汇聚层/接入层交换机,将作为 VTP Client,可决定加入的 VTP 域和 VLAN。
目前该网络都属于 VLAN 1,也即这些 PC 是可以相互通信的。前面说过,无论对于性能、管理还是安全等而言,现实中我们必须进行 VLAN 划分。
现在我们的要求是:新建两个 VLAN,然后让 PC0 和 PC1 属于 VLAN 2,PC1 和 PC3 属于 VLAN 3。
我们将在核心交换机 3560上进行如下工作:
1、设置为 server 模式,VTP 域为 cqjtu
2、新建 VLAN 2,网络号 192.168.1.0/24,网关 192.168.1.1
3、新建 VLAN 3,网络号 192.168.2.0/24,网关 192.168.2.1
3560 VTP Server 配置:
Switch>en Switch#conf t Switch(config)#hostname 3560 // 更改交换机名称(可选)
3560(config)#vtp domain cqjtu // 设置 VTP 域名称为 cqjtu 3560(config)#vtp
mode server // 设置其为 VTP 服务器模式 3560(config)#vlan 2 //
新建VLAN 2 3560(config-vlan)#name computer // 设置 VLAN 2 的别名(可选)
3560(config-vlan)#exit 3560(config)#vlan 3 // 再建 VLAN 3
3560(config-vlan)#name communication //设置 VLAN 2 的别名(可选)
3560(config-vlan)#exit 3560(config)#int vlan 2 // 配置接口 VLAN
2,它将是该子网(左边)的网关 3560(config-if)#ip address 192.168.1.1 255.255.255.0
3560(config-if)#exit 3560(config)#int vlan 3 // 配置接口 VLAN
3,它将是该子网(右边)的网关 3560(config-if)#ip address 192.168.2.1 255.255.255.0
我们将在左边交换机 2960A 上进行如下工作:
1、加入名为 cqjtu 的 VTP 域
2、配置与核心交换机 3560 连接的千兆接口 g0/1 为 trunk 模式
3、将接口 f0/1 划分到 VLAN 2 中
4、将接口 f0/2 划分到 VLAN 3 中
2960A(左边) VTP Client 配置:
Switch>en Switch#conf t Switch(config)#hostname 2960A //
更改交换机名称(可选) 2960A(config)#vtp domain cqjtu // 加入名为 cqjtu 的 VTP 域
2960A(config)#vtp mode client // 设置模式为 VTP 客户 2960A(config)#int
g0/1 // 配置与核心交换机 3560 连接的 g0/1 千兆接口 2960A(config-if)#switchport
mode trunk // 设置该接口为中继(trunk)模式 2960A(config-if)#switchport trunk
allowed vlan all // 允许为所有的 VLAN 中继 2960A(config-if)#exit
2960A(config)#int f0/1 // 配置接口 1 2960A(config-if)#switchport mode
access // 设置该接口为正常访问模式 2960A(config-if)#switchport access vlan 2
// 将接口划分到 VLAN 2 2960A(config-if)#exit 2960A(config)#int f0/2 //
配置接口 2 2960A(config-if)#switchport mode access // 设置该接口为正常访问模式
2960A(config-if)#switchport access vlan 3 // 将接口划分到 VLAN 3
我们将在右边交换机 2960B 上进行同样的工作:
1、加入名为 cqjtu VTP 域
2、配置与核心交换机 3560 连接的千兆接口 g0/1 为 trunk 模式
3、将接口 f0/1 划分到 VLAN 2 中
4、将接口 f0/2 划分到 VLAN 3 中
2960B(右边) VTP Client 配置:
Switch>en Switch#conf t Switch(config)#hostname 2960B //
更改交换机名称(可选) 2960B(config)#vtp domain cqjtu // 加入名为 cqjtu 的 VTP 域
2960B(config)#vtp mode client // 设置模式为 VTP 客户 2960B(config)#int
g0/1 // 配置与核心交换机 3560 连接的 g0/1 千兆接口 2960B(config-if)#switchport
mode trunk // 设置该接口为中继(trunk)模式 2960B(config-if)#switchport trunk
allowed vlan all // 允许为所有的 VLAN 中继 2960B(config-if)#exit
2960B(config)#int f0/1 // 配置接口 1 2960B(config-if)#switchport mode
access // 设置该接口为正常访问模式 2960B(config-if)#switchport access vlan 2
// 将接口划分到 VLAN 2 2960B(config-if)#exit 2960B(config)#int f0/2 //
配置接口 2 2960B(config-if)#switchport mode access // 设置该接口为正常访问模式
2960B(config-if)#switchport access vlan 3 // 将接口划分到 VLAN 3
至此,各交换机配置完毕。
秘籍
此时在 3 个交换机的特权模式下,都可使用show vtp status命令查看 VTP 状态,使用show vlan命令查看 VLAN 状态
各 PC 连接的交换机和接口以及网络配置如下:
至此,VTP 配置完成。同 VLAN 可以 ping 通,而不同 VLAN 不行(即使在同一交换机下,如从 PC0 到 PC1),且能够方便的统一规划和管理。
试一试
使用 PC0(192.168.1.2) ping PC1(192.168.2.2) 的结果如何?使用 PC0 ping PC2 的结果如何?想想为什么?
PC0 pingPC1不通,因为不属于同一vlan,PC0pingPC2通,因为PC0和PC2属于同一vlan下
VTP 只是给我们划分和管理 VLAN 提供了方便,由上面的测试得知,目前我们仍然不能在 VLAN 间通信。
因为默认的,VLAN 间是不允许进行通信,此时我们需要所谓的独臂路由器在 VLAN 间为其进行转发!
我们使用的核心交换机 3560 是个 3 层交换机,可工作在网络层,也称路由交换机,即具有路由功能,能进行这种转发操作。
3560 交换机配置:
3560>en 3560#conf t 3560(config)#int g0/1 // 配置连接左边 2960A 交换机的接口
3560(config-if)#switchport trunk encapsulation dot1q // 封装 VLAN 协议
3560(config-if)#switchport mode trunk // 设置为中继模式
3560(config-if)#switchport trunk allowed vlan all // 在所有 VLAN 间转发
3560(config-if)#exit 3560(config)#int g0/2 // 配置连接右边 2960B 交换机的接口
3560(config-if)#switchport trunk encapsulation dot1q //封装 VLAN 协议
3560(config-if)#switchport mode trunk // 设置为中继模式
3560(config-if)#switchport trunk allowed vlan all // 在所有 VLAN 间转发
3560(config-if)#exit 3560(config)#ip routing // 启用路由转发功能
至此,各 VLAN 中的 PC 可以正常通信。
试一试
现在再使用 PC0(192.168.1.2) ping PC1(192.168.2.2) 的结果如何?使用 PC0 ping PC2
的结果如何?
答:可以Ping通
动态主机配置 DHCP、域名解析 DNS 以及 Web 服务在日常应用中作用巨大,我们构建如下简单的拓扑来进行练习。
该拓扑中,服务器及客户机都连在同一交换机上。为简单起见,服务器 Server-PT 同时作为 DHCP、DNS 以及 Web 服务器,各客户机无需配置,将自动获取网络配置。
点击 CPT 拓扑图中的 Server 图标,设置其静态 IP 地址为 19.89.6.4/24,然后选择 Service 进行如下相关配置
试一试
1、先查看各 PC,看看是否获得网络配置
2、因为我们在 DNS 服务器中把谷歌和百度的 IP 都设为了 19.89.6.4,即
Server-PT,所以,如果打开 PC0 的浏览器,输入 www.google.com 或者
www.baidu.com,我们都应该看到默认的 Server-PT 这个 Web 服务器的主页(你也可进行编辑)
这次实验用CPT进行了一系列模拟仿真,让我从一个较为真实的层面学习了计算机网络的相关知识,同时也更后悔为什么考试之前没有来做实验部分。虽然计算机网络实验结束了,但是考虑到未来还要面临考研,所以我还要继续学习计算机网络的知识,这一时期先把基础打牢固。