linux 网桥学习

2024-06-11 05:44
文章标签 linux 学习 网桥

本文主要是介绍linux 网桥学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言: 本文来学习一下linux网桥概念和网桥配置

1. linux网桥概念

网桥,类似于中继器,连接局域网中两个或者多个网段。它与中继器的不同之处就在于它能够解析它收发的数据,读取目标地址信息(MAC),并决定是否向所连接的其他网段转发数据包。为了能够决策向那个网段发送数据包,网桥学习接收到数据包的源MAC地址,在本地建立一个以MAC和端口为记录项的信息数据库。

有时, 会有需要将一个物理网络分成两个独立的网段, 而不是创建新的 IP 子网然后将其通过路由器相连。 以这种方式连接两个网络的设备称为 “网桥 (bridge)”。网桥通过学习每个网络接口上的 MAC 层地址 (以太网地址) 工作。 只当数据包的源地址和目标地址处于不同的网络时, 网桥才进行转发。在很多方面,网桥就像一个带有很少端口的以太网交换机。

2. 网桥和交换机的区别

提到网桥就不得不提起集线器,集线器(HUB)的功能就是将多台主机互联起来,但是多台主机在一个广播域里面就会造成广播风暴。
网桥的作用就是为了将广播域分割,将一个广播域,分割为两个广播域,具体实现就是将网桥两端各连接一个集线器,在由集线器去连接主机。
如下图所示:

在这里插入图片描述
工作原理:

主机A想跟主机B通信时会发送ARP广播,这个时候网桥MAC-PORTNUM表还是空的,网桥会转发数据到DEF主机的网路中,并在表中添加一条A主机MAC地址对应网桥的端口,等下次A主机再次和B主机通信时,网桥会丢弃ARP此数据包,将广播范围缩少了。

当主机A想和D主机所处的网络通讯时,主机A发送ARP广播,由于网桥的mac-portnum表中没有主机D对应的MAC地址,所以数据包将被转发到D主机所有在网络中进行广播,找到D对应的MAC地址并将MAC地址和对应的端口号写入到 mac-portnum表中。

总结:
网桥的两个端口分为连接两个局域网,网桥的mac-portnum表中记录着, 连接ABC主机MAC地址对应的端口,连接DCE主机MAC地址对应的端口,网桥属于1个端口对应多个NAC地址。

交换机是改良的网桥,交换机的工作模式如下;
在这里插入图片描述
所有的主机都连接到交换机上,主机通讯时会发送一次ARP广播请求MAC,交换机会记录MAC对应的端口号,属于一对一的方式,后续通讯时直接转发到目的主机,一个端口就是一个广播域。

网桥和交换机的工作模式对比:
网桥属于1个端口对应多个MAC地址
交换机属于一个端口对应一个MAC地址

3. 如何配置网桥

3.1. 使用命令行方式配置

配置网桥可以使用ip或者brctl命令,一般使用brctl命令,不过需要安装工具包: bridge-utils
brctl常用命令:

brctl show查看所有网桥
brctl addbr <网桥名称>添加网桥
brctl delbr <网桥名称>删除网桥
brctl addif <网桥名称> <网络设备名称>将网卡设备添加到网桥,作为网桥端口
brctl delif <网桥名称> <网络设备名称>将网卡设备从网桥里删除

使用命令行创建的网桥会在重启后失效

# 创建网桥
[root@localhost ~]# brctl addbr br0
[root@localhost ~]# brctl show
bridge name	bridge id		STP enabled	interfaces
br0		8000.000000000000	no	
# 将网卡设备加入到网桥作为网桥的端口,此时IP不生效
[root@localhost ~]# brctl addif br0 ens33 ens36
ridge name	bridge id		STP enabled	interfaces
br0		8000.000000000000	no	ens33ens36

使用ifconfig 命令需要下载net-tools包

# 清空网桥端口IP
[root@localhost ~]# ifconfig ens33 0.0.0.0 
[root@localhost ~]# ifconfig ens36 0.0.0.0
# 为网桥设置IP
[root@localhost ~]# ip add dev br0 192.168.92.100/24
# 启动网卡设备
[root@localhost ~]# ip link set br0 up
# 设置默认网关(根据实际情况配置)
[root@localhost ~]#  ip route add default via 192.168.92.2

notice: 命令行方式创建的网桥和一系列配置都将在重启系统后失效。

3.2. 使用配置文件的方式创建网桥

使用配置文件的方式创建网桥和配置信息永久生效

3.2.1. 创建网桥

# 进入到网卡配置目录,创建网桥配置文件,并配置ip地址和网关
[root@localhost ~]# cd /etc/sysconfig/network-scripts
[root@localhost network-scripts]# vi ifcfg-br0
NAME=br0
DEVICE=br0
TYPE=Bridge
ONBOOT=yes
IPADDR=192.168.92.100
NETMASK=255.255.255.0
GATEWAY=192.168.92.2
# 重启网络使配置生效
[root@localhost network-scripts]# systemctl restart network
[root@localhost network-scripts]# brctl show
bridge name	bridge id		STP enabled	interfaces
br0		8000.000000000000	no

3.2.2. 将网卡添加到网桥并配置地址

a. 修改网卡配置文件,将网卡设备桥接到br0网桥,不设置IP地址
网卡为ens33,ens36

Ps:修改网卡配置文件需要注意的地方是:

  1. 设置静态获取地址,不用配置IP
  2. BRIDGE=br0 配置为网桥名称,桥接到网桥上
[root@localhost network-scripts]# vi  ifcfg-ens33
TYPE="Ethernet"
DEVICE="ens33"
BOOTPROTO="none"
ONBOOT="yes"
BRIDGE=br0
[root@localhost network-scripts]# vi  ifcfg-ens36
TYPE="Ethernet"
DEVICE="ens36"
BOOTPROTO="none"
ONBOOT="yes"
BRIDGE=br0

b. 重启网络查看网卡设备是否被添加到网桥

[root@localhost network-scripts]# systemctl restart network
[root@localhost network-scripts]# brctl show
bridge name	bridge id		STP enabled	interfaces
br0		8000.000c2957ffc5	no			ens33ens36

3.2.3. 将网卡配置为支持VLAN

需要修改ens33和ens36网卡配置文件

Ps: 需要注意要修改的配置为:

  1. TYPE=Vlan 用于指示该网卡的类型为 VLAN 接口。
  2. VLAN=yes 表示启用了该网卡的 VLAN 功能,允许在该网卡上配置和使用虚拟局域网。

a. 修改配置文件

[root@localhost network-scripts]# vi ifcfg-ens33
TYPE="Vlan"
VLAN=yes
DEVICE="ens33"
BOOTPROTO="none"
ONBOOT="yes"
BRIDGE=br0
[root@localhost network-scripts]# vi ifcfg-ens36
TYPE="Vlan"
VLAN=yes
DEVICE="ens36"
BOOTPROTO="none"
ONBOOT="yes"
BRIDGE=br0

b. 重启网络

[root@localhost network-scripts]# systemctl restart network

这篇关于linux 网桥学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050339

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更