linux网桥

  linux网桥是一种以同种协议连接两个局域网的产品。可以把它看成是一个决定发送的包是到自己的局域网还是到另一个局域网的设备。linux网桥检查局域网上所有的包,在同一个局域网中传送它,如果不是同一个网中的,就将它发到别的网上。

原理

  网桥是连接两个局域网的存储转发设备,用它可以完成具有相同或相似体系结构网络系统的连接。一般情况下,被连接的网络系统都具有相同的逻辑链路控制规程(LLC),但媒体访问控制协议(MAC)可以不同。

  网桥工作在数据链路层,将两个LAN连起来,根据MAC地址来转发帧,可以看作一个“低层的路由器”(路由器工作在网络层,根据网络地址如IP地址进行转发)。 远程网桥通过一个通常较慢的链路(如电话线)连接两个远程LAN,对本地网桥而言,性能比较重要,而对远程网桥而言,在长距离上可正常运行是更重要的。

功能

  网桥的功能在延长网络跨度上类似于中继器,然而它能提供智能化连接服务, 即根据帧的终点地址处于哪一网段来进行转发和滤除。网桥对站点所处网段的了 解是靠“自学习”实现的。

  当使用网桥连接两段LAN 时,网桥对来自网段1 的MAC 帧,首先要检查其终 点地址。如果该帧是发往网段1 上某一站的,网桥则不将帧转发到网段2 ,而将 其滤除;如果该帧是发往网段2 上某一站的,网桥则将它转发到网段2.这表明, 如果LAN1和LAN2上各有一对用户在本网段上同时进行通信,显然是可以实现的。 因为网桥起到了隔离作用。可以看出,网桥在一定条件下具有增加网络带宽 的作用。

使用

  要配置网桥,要网桥的配置工具bridge-utils。源代码可以在https://bridge.sourceforge.net/bridge-utils/ 下载。编译成功之后,生成网桥配置的工具名称为brctl。

  配置说明:

  有五台主机。其中一台主机装有linux ,安装了网桥模块,而且有四块物理网卡,分别连接同一网段的其他主机。我们希望其成为一个网桥,为其他四台主机(IP分别为192.168.1.2 ,192.168.1.3,192.168.1.4,192.168.1.5) 之间转发数据包。同时,为了方便管理,希望网桥能够有一个IP(192.168.1.1),那样管理员就可以在192.168.1.0/24网段内的主机上telnet到网桥,对其进行配置,实现远程管理。

  我们为这个逻辑网段一个名称,br_192。首先需要配置这样一个逻辑网段。

  # brctl addbr br_192            (建立一个逻辑网段,名称为br_192)

  实际上,我们可以把逻辑网段192.168.1.0/24看作使一个VLAN ,而br_192则是这个VLAN的名称。

  建立一个逻辑网段之后,我们还需要为这个网段分配特定的端口。在Linux中,一个端口实际上就是一个物理网卡。而每个物理网卡的名称则分别为 eth0,eth1,eth2,eth3。我们需要把每个网卡一一和br_192这个网段联系起来,作为br_192中的一个端口。

  # brctl addif br_192 eth0            (让eth0成为br_192的一个端口)

  # brctl addif br_192 eth1            (让eth1成为br_192的一个端口)

  # brctl addif br_192 eth2            (让eth2成为br_192的一个端口)

  # brctl addif br_192 eth3            (让eth3成为br_192的一个端口)

  网桥的每个物理网卡作为一个端口,运行于混杂模式,而且是在链路层工作,所以就不需要IP了。

  # ifconfig eth0 0.0.0.0

  # ifconfig eth1 0.0.0.0

  # ifconfig eth2 0.0.0.0

  # ifconfig eth3 0.0.0.0

  然后给br_192的虚拟网卡配置IP:192.168.1.1。那样就能远程管理网桥。

  # ifconfig br_192 192.168.1.1

  给br_192配置了IP之后,网桥就能够工作了。192.168.1.0/24网段内的主机都可以telnet到网桥上对其进行配置。

  以上配置的是一个逻辑网段,实际上Linux网桥也能配置成多个逻辑网段(相当于交换机中划分多个VLAN)。具体的方法可以参考bridge-util中的HOWTO

设置步骤

  1、创建网桥设备 br0:

  brctl addbr br0

  2、向br0中添加网卡:

  eth0  eth1

  brctl addif eth0

  brctl addif eth1

  3、从网桥中删除网卡:

  eth0 eth1

  brctl delif eth0

  brctl delif eth1

  4、删除网桥 br0 :

  brctl  delbr  br0

工作流程

  1. 检查收到的信号,解释0和1的含义,并找出帧中的目的MAC地址。

  2. 如果具有该目的的MAC地址的帧能够通过网桥上不同的接口到达目的地(不是帧到达网桥的那个接口),则通过重新生成信号来传输这帧。(这个过程叫做转发。)

  3. 如果该帧到达的接口就是目的地址可达到的端口,则丢弃该帧。(这个过程叫做过滤。)

更多精彩内容,请登入维库电子通https://wiki.dzsc.com

相关百科