交换机是怎么做到一个端口就是一个冲突域的?

2025-03-29 15:20:14
推荐回答(1个)
回答1:

一个冲突域由所有能够看到同一个冲突或者被该冲突涉及到的设备组成。以太网使用C S M A / C D(Carrier Sense Multiple Access with Collision Detection,带有冲突监测的载波侦听多址访问)技术来保证同一时刻,只有一个节点能够在冲突域内传送数据。
一台交换机如果没有任何vlan,网段设置就相当于一个hub,这时整台交换机的端口传输的数据就在一个冲突域。但是交换机不外传广播包(跨vlan传播)所以,交换机是冲突域的结点。
以10M的Switch和Hub为例。交换机的每个port就是一个独立的冲突域,如果这个port只接一台机器,那就不存在冲突的问题了,独享10M带宽。如果是HUB,那所有端口都在一个冲突域里,所有机器共享10M带宽。
重新澄清一下,A口-->B口发数据的时候,Hub是通过向所有port上发送来实现,而交换机是通过switch芯片来交换,只向B发送,其他口上是sniffer不到的。 OSI的7层模型里 HUB工作在第一层物理层 由于物理层传输的是电信号,如果我有2台机器一起发电信号,信号岂不是混乱了么?所以用C S M A / C D来避免冲突。注意是避免不是消除冲突,冲突依然存在。因此冲突域被定义为:连接在同一导线上的所有工作站的集合,或者说是同一物理网段上所有节点的集合或以太网上竞争同一带宽的节点集合。所以冲突域是定义在物理层上的。
而SWITCH工作在第二层数据链路层,交换机保存每个PORT的MAC地址,根据MAC地址传输FRAM。每个PORT后面可以连接不同的物理网段, 所以说交换机的每个PORT就是一个冲突域。