网络指南
在 RHEL 7 中配置和管理网络、网络接口和网络服务
摘要
部分 I. 开始前
第 1 章 网络主题概述
1.1. IP 与非 IP 网络比较
网络通信的类型
- IP 网络
- 通过 Internet 协议地址通信的网络.IP 网络是在互联网和大多数内部网络中实现的。以太网、Cable Modems、DSL Modems、拨号调制解调器、无线网络和 VPN 连接都是典型示例。
- 非 IP 网络
- 用于通过较低层而不是传输层进行沟通的网络。请注意这些网络很少被使用。InfiniBand 是一个非 IP 网络,如 第 13 章 配置 InfiniBand 和 RDMA 网络 所述。
1.2. 静态与动态 IP 地址比较
- 静态 IP 地址
- 当为设备分配静态 IP 地址时,该地址不会随着时间变化,除非手动更改。如果需要,建议使用静态
IP 地址
:- 确保
DNS
等服务器的网络地址一致性以及验证服务器。 - 使用独立于其他网络基础结构的带外管理设备。
有关自动配置和管理的更多信息,请参阅Red Hat Enterprise Linux 7 系统管理员指南中的 OpenLMI 章节。《Red Hat Enterprise Linux 7 安装指南》记录了 Kickstart 文件的使用,它也可用于自动分配网络设置。 - 动态 IP 地址
- 当为设备分配一个动态 IP 地址时,地址会随着时间推移而变化。因此,建议偶尔连接到网络的设备在重启计算机后可能会更改 IP 地址。动态 IP 地址更灵活,更容易设置和管理。动态主机控制协议 (DHCP)是一种传统方法,用于动态将网络配置分配到主机。如需更多信息,请参阅 第 14.1 节 “为什么使用 DHCP?”。您还可以使用 nmcli 工具,如 第 3.3.7 节 “使用 nmcli 添加和配置动态以太网连接” 所述。注意没有严格的规则来定义何时使用静态或动态 IP 地址。它取决于用户的需求、偏好和网络环境。默认情况下,NetworkManager 调用
DHCP
客户端,dhclient。
1.3. 配置 DHCP 客户端行为
DHCP
客户端,dhclient。
请求 IP 地址
DHCP
连接启动时,dhcp 客户端会从 DHCP
服务器请求 IP 地址。默认情况下,dhcp 客户端等待此请求完成的时间为 60 秒。您可以使用 nmcli 工具或 /etc/sysconfig/network -scripts/ifcfg-ifname文件中的 IPV4_DHCP_TIMEOUT
选项来配置ipv4.dhcp-
timeout
属性。例如,使用 nmcli:
~]# nmcli connection modify enp1s0 ipv4.dhcp-timeout 10
如果在这个间隔内无法获取地址,则 IPv4 配置会失败。整个连接也可能失败,这取决于 ipv4.may-fail
属性:
- If
ipv4.may-fail
被设置为yes
(默认),连接的状态取决于 IPv6 配置:- 如果启用了 IPv6 配置并成功,连接将被激活,但无法再次重试 IPv4 配置。
- 如果禁用或未配置 IPv6 配置,连接会失败。
- If
ipv4.may-fail
设置为没有
停用连接。在这种情况下:- 如果启用了
连接的 autoconnect
属性,NetworkManager 会重试以激活连接次数,次数与autoconnect-retries
属性中设置的次数相同。默认值为 4。 - 如果连接仍然无法获得 dhcp 地址,则自动激活会失败。请注意,5 分钟后,自动连接过程将再次启动,dhcp 客户端会尝试从 dhcp 服务器获取地址。
请求租用续订
ipv4.dhcp-timeout
属性设置为秒(默认为 60)以获取租用。如果在尝试过程中收到回复,则进程将停止,并且您的租期续订。
- If
ipv4.may-fail
设置为yes
(默认)和 IPv6 配置成功,连接将被激活,dhcp 客户端每 2 分钟重新重新启动一次。 - If
ipv4.may-fail
设置为no
,则连接将被停用。在这种情况下,如果连接启用了autoconnect
属性,则从头激活连接。
1.3.1. 使 DHCPv4 持久
ipv4.dhcp-timeout
属性设置为 32 位整数(MAXINT32)的最大值,即 2147483647
或 infinity
值:
~]$ nmcli connection modify enps1s0 ipv4.dhcp-timeout infinity
因此,NetworkManager 永远不会停止尝试从 DHCP 服务器获取或续订租期,直到成功为止。
enp1s0 配置文件中使用 nmcli 手动将静态 IP 添加到 /etc/sysconfig/network-scripts/ifcfg- enp1s0
配置文件中的 IPADDR
属性中:
~]$ nmcli connection modify enp1s0 ipv4.address 192.168.122.88/24
1.4. 设置 Wireless Regulatory 域
Govern.bin
文件来保存其规范数据库信息。
/etc/sysconfig/regdomain
文件中定义 COUNTRY
环境变量。
setregdomain(1)
手册页 - 根据国家代码设置规范域.CRDA(8)man
page - 向内核发送给定 ISO 或 IEC 3166 alpha2 的无线规范域.Govern.bin(5)
手册页 - 显示 Linux 无线法规数据库.iw(8)手册页
- 显示或操作无线设备及其配置。
1.5. 配置 netconsole
netconsole
内核模块允许通过网络将内核消息记录到另一台计算机。
netconsole
,您需要具有一个在网络上正确配置的 rsyslog
服务器。
过程 1.1. 为 netconsole 配置 rsyslog 服务器
- 将
rsyslogd
守护进程配置为侦听 514/udp 端口,并通过取消注释/etc/rsyslog.conf
文件的MODULES
部分中的以下行从网络接收信息:$ModLoad imudp $UDPServerRun 514
- 重启
rsyslogd
服务以使更改生效:]# systemctl restart rsyslog
- 验证
rsyslogd
是否在侦听 514/udp 端口:]# netstat -l | grep syslog udp 0 0 0.0.0.0:syslog 0.0.0.0:* udp6 0 0 [::]:syslog [::]:*
netstat -l 输出中的0.0.0.0:syslog
和 [::]:syslog
值表示rsyslogd
正在侦听/etc/services
文件中定义的默认netconsole
端口:]$ cat /etc/services | grep syslog syslog 514/udp syslog-conn 601/tcp # Reliable Syslog Service syslog-conn 601/udp # Reliable Syslog Service syslog-tls 6514/tcp # Syslog over TLS syslog-tls 6514/udp # Syslog over TLS syslog-tls 6514/dccp # Syslog over TLS
Netconsole
使用 /etc/sysconfig/netconsole
文件进行配置,该文件是 initscripts 软件包的一部分。默认情况下会安装此软件包,它还提供 netconsole
服务。
过程 1.2. 配置发送机器
- 在
/etc/sysconfig/netconsole
文件中设置SYSLOGADDR
变量的值,以匹配syslogd
服务器的 IP 地址。例如:SYSLOGADDR=192.168.0.1
- 重启
netconsole
服务以使更改生效:]# systemctl restart netconsole.service
- 在重启系统后启用
netconsole.service
运行:]# systemctl enable netconsole.service
- 在
/var/log/messages
文件中或rsyslog.conf
中指定的文件中查看来自客户端的netconsole
消息。]# cat /var/log/messages
默认情况下,rsyslogd
和 netconsole.service
使用端口 514。要使用不同的端口,请将 /etc/rsyslog.conf
中的以下行改为所需的端口号:
$UDPServerRun <PORT>
/etc/sysconfig/netconsole
文件中的以下行:
SYSLOGPORT=514
netconsole
配置和故障排除提示的更多信息,请参阅 Netconsole 内核文档。
1.6. 使用带有 sysctl 的网络内核可调项
sysctl
实用程序使用某些内核可调项,您可以在运行中的系统上调整网络配置,并直接影响网络性能。
/etc/sysctl.conf
文件添加行。
sysctl
参数列表,以 root
用户身份输入:
~]# sysctl -a
sysctl
的网络内核可调项的详情,请参阅《系统管理员指南》 的使用带有多个接口的 PTP 部分。
1.7. 使用 ncat 工具管理数据
IPv4
和 IPv6
、打开连接、发送数据包、执行端口扫描,并支持更高级别的功能,如 SSL
和连接代理。
安装 ncat
root
用户身份输入:
~]# yum install ncat
ncat 用例的简短选择
例 1.1. 启用客户端和服务器之间的通信
- 将客户端机器设置为侦听 TCP 端口 8080 上的连接:
~]$ ncat -l 8080
- 在服务器机器中指定客户端的 IP 地址并使用相同的端口号:
~]$ ncat 10.0.11.60 8080
您可以在连接两侧发送消息,它们会显示在本地和远程计算机上。 - 按
Ctrl+D
关闭 TCP 连接。
-u
选项的相同 nc 命令。例如:
~]$ ncat -u -l 8080
例 1.2. 发送文件
- 在客户端机器上侦听将文件传输到服务器机器的特定端口:
~]$ ncat -l 8080 > outputfile
- 在服务器机器上,指定客户端的 IP 地址、要传输的端口和文件:
~]$ ncat -l 10.0.11.60 8080 < inputfile
~]$ ncat -l 8080 < inputfile
~]$ ncat -l 10.0.11.60 8080 > outputfile
例 1.3. 创建 HTTP 代理服务器
~]$ ncat -l --proxy-type http localhost 8080
例 1.4. 端口扫描
-z
选项并指定要扫描的端口范围:
~]$ ncat -z 10.0.11.60 80-90
Connection to 192.168.0.1 80 port [tcp/http] succeeded!
例 1.5. 使用 SSL 设置安全客户端-服务器通信
SSL
:
~]$ ncat -e /bin/bash -k -l 8080 --ssl
~]$ ncat --ssl 10.0.11.60 8080
SSL
连接的真正机密性,服务器需要 --ssl-cert
和 --ssl-key
选项,客户端需要 --ssl-verify
和 --ssl-trustfile
选项。有关 OpenSSL
的详情,请参考安全指南中的使用 OpenSSL 部分。
部分 II. 管理 IP 网络
第 2 章 NetworkManager 入门
2.1. NetworkManager 概述
ifcfg
类型配置文件仍受支持。如需更多信息,请参阅 第 2.6 节 “将 NetworkManager 与网络脚本搭配使用”。
2.1.1. 使用 NetworkManager 的好处
- 更轻松地进行网络配置: NetworkManager 确保网络连接正常工作。当发现系统中没有网络配置但存在网络设备时,NetworkManager 会创建临时连接以提供连接。
- 支持配置灵活性。例如:配置 WiFi 接口,NetworkManager 会扫描并显示可用的 wifi 网络。您可以选择一个接口,NetworkManager 会显示在重启过程后提供自动连接所需的凭证。NetworkManager 可以配置网络别名、IP 地址、静态路由、DNS 信息和 VPN 连接,以及许多特定于连接的参数。您可以修改配置选项以反应您的需要。
- 通过 D-Bus 提供 API,允许应用程序查询和控制网络配置和状态。这样,应用程序可以通过 D-BUS 检查或配置网络。例如,通过
Web
浏览器监控和配置服务器的 Web 控制台界面使用 NetworkManager D-BUS 接口来配置网络。 - 重启过程后保持设备状态,并接管在重启过程中将其设定为受管模式的接口。
- 处理没有被显式设置但由用户或者其他网络设备手动控制的设备。
2.2. 安装 NetworkManager
root
用户身份输入:
~]# yum install NetworkManager
2.3. 检查 NetworkManager 的状态
~]$ systemctl status NetworkManager
NetworkManager.service - Network Manager
Loaded: loaded (/lib/systemd/system/NetworkManager.service; enabled)
Active: active (running) since Fri, 08 Mar 2013 12:50:04 +0100; 3 days ago
Active: inactive (dead)
。
2.4. 启动 NetworkManager
~]# systemctl start NetworkManager
~]# systemctl enable NetworkManager
2.5. NetworkManager 工具
应用程序或工具 | 描述 |
---|---|
nmcli | 命令行工具可让用户和脚本与 NetworkManager 交互。请注意,nmcli 可以在没有 GUI 的系统上使用,如服务器来控制 NetworkManager 的所有方面。它的功能与 GUI 工具相同。 |
nmtui | NetworkManager的基于 curses 的简单文本用户界面(TUI) |
nm-connection-editor | 控制中心实用程序尚未处理的特定任务 (如配置绑定和成组连接)的图形用户界面工具。您可以添加、删除和修改 NetworkManager 存储的网络连接。要启动它,在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
|
control-center | GNOME Shell 提供的图形用户界面工具,可供桌面用户使用。它整合了网络设置工具。要启动它,请按 Super 键进入 Activities Overview,键入 Network,然后按 Enter 键。此时会出现网络设置工具。 |
网络连接图标 | GNOME Shell 提供的图形用户界面工具代表网络连接状态,如 NetworkManager 报告。该图标有多种状态,充当您当前使用的连接类型的可视化指示。 |
2.6. 将 NetworkManager 与网络脚本搭配使用
网络脚本引用脚本
/etc/init.d/network
及其调用的其他已安装脚本。虽然 NetworkManager 提供默认网络服务,但脚本和 NetworkManager 可以并行运行并协同工作。红帽建议先测试它们。
运行网络脚本
systemctl start|stop|restart|status
network
systemctl 工具会清除任何现有环境变量并确保正确执行。
/etc/init.d/网络检查
,以避免对 NetworkManager 的连接进行篡改。NetworkManager 旨在作为使用 sysconfig 配置文件的主要应用,/etc/init.d/network
则是辅助应用程序。
/etc/init.d/network
脚本运行:
- 手动 - 使用其中一个 systemctl 命令
start|stop|restart
网络,或者 - 如果网络服务已启用,则引导和关闭 - 作为 systemctl enable network 命令的结果。
ifup
和 ifdown
脚本。
~]# systemctl restart network.service
这会关闭并启动所有网络接口卡(NIC)以加载新配置。如需更多信息,请参阅 Red Hat Knowledgebase 解决方案 Reload 和 force-reload 选项用于网络服务。
在网络脚本中使用自定义命令
/etc/init.d/network服务控制这些设备时,才会在 /sbin/ifup
-local
、ifdown-pre-local
脚本中执行自定义命令。默认情况下,ifup-local
文件不存在。如果需要,在 /sbin/
目录下创建它。
ifup-local
脚本仅可由 initscripts 读取,NetworkManager 不可读取。要使用 NetworkManager 运行自定义脚本,请在分配程序.d/
目录下创建它。请参阅 “运行 Dispatcher 脚本”一节。
网络脚本
和 NetworkManager 运行自定义任务。如果启用了 NetworkManager
,ifup 和 ifdown
脚本将询问 NetworkManager 是否管理相关的接口,该接口可从 ifcfg
文件的 “DEVICE=” 行中找到。
- 调用 ifup
- 当您调用
ifup
且设备由 NetworkManager 管理时,有两个选项:- 如果该设备尚未连接
,则是否会询问 NetworkManager 启动连接。
- 如果设备已经连接,则不执行任何操作。
- 调用 ifdown
- 当您调用
ifdown 且设备由
NetworkManager 管理时 :ifdown
要求 NetworkManager 终止连接。
ifup
或 ifdown
,该脚本将使用自 NetworkManager 存在之前的较旧的非网络管理器机制启动连接。
运行 Dispatcher 脚本
默认情况下,/etc/NetworkManager/dispatcher.d/
目录存在,NetworkManager 会以字母顺序运行脚本。每个脚本必须是 root
拥有的 可执行文件,并且必须仅对文件所有者具有 写入权限
。有关运行 NetworkManager 分配程序脚本的更多信息,请参阅红帽知识库解决方案如何编写 NetworkManager 分配程序脚本以应用 ethtool 命令。
2.7. 使用 NetworkManager 和 sysconfig 文件
/etc/sysconfig/
目录是配置文件和脚本的位置。除 VPN、移动宽带和 PPPoE 配置外,大多数网络配置信息都存储在 /etc/NetworkManager/
子目录中。例如,特定于接口的信息存储在 /etc/sysconfig/network-scripts/
目录下的 ifcfg
文件中。
/etc/sysconfig/network
文件。VPN、移动宽带和 PPPoE 连接的信息存储在 /etc/NetworkManager/system-connections/
中。
ifcfg
文件,NetworkManager 会自动不知道该更改,且必须提示您注意到更改。如果您使用其中一个工具更新 NetworkManager 配置集设置,NetworkManager 不会实现这些更改,直到您使用该配置集重新连接为止。例如,如果使用编辑器更改了配置文件,NetworkManager 必须再次读取配置文件。
root
用户身份输入 以重新载入所有连接配置集:
~]# nmcli connection reload
,ifcfg-ifname :
~]# nmcli con load /etc/sysconfig/network-scripts/ifcfg-ifname
~]# nmcli dev disconnect interface-name
~]# nmcli con up interface-name
ifup
命令时会尝试触发 NetworkManager。有关网络脚本的说明,请参阅 第 2.6 节 “将 NetworkManager 与网络脚本搭配使用”。
ifup
脚本是一个通用脚本,可执行一些操作,然后调用特定于接口的脚本,如 ifup-device_name
、ifup-wireless
、ifup-ppp
等。当用户手动运行 ifup enp1s0 时 :
如果查找名为
/etc/sysconfig/network-scripts/ifcfg-enp1s0
的文件;- 如果
ifcfg
文件存在,如果该文件中查找
TYPE
键,以确定要调用的特定类型脚本; ifup
会调用ifup-wireless
或ifup-device_name
,基于TYPE
;- 特定于类型的脚本进行特定于类型的设置;
- 特定于类型的脚本可让常见功能执行
IP
相关任务,如DHCP
或静态设置。
在引导时,/etc/init.d/network
会遍历所有 ifcfg
文件,以及每个具有 ONBOOT=yes 的文件读取所有 ifcfg 文件,它将检查 NetworkManager 是否已经从该 ifcfg
文件中启动 DEVICE。如果 NetworkManager 正在启动该设备或已启动该设备,则不再为该文件执行任何操作,并检查下一个 ONBOOT=yes 文件。如果 NetworkManager 尚未启动该设备,则 initscripts 会继续其传统行为并调用 ifup(如果是该
ifcfg
文件)。
ifcfg
文件应该在系统启动时(NetworkManager )或 initscripts 启动。这样可确保 NetworkManager 无法处理的某些传统网络类型(如 ISDN 或模拟的拨号模式ms)以及 NetworkManager 尚不支持的新应用程序仍能由 initscripts 正确启动,即使 NetworkManager 无法处理它们。
/etc
目录中的任何位置,或存储在与实时文件相同的位置,因为脚本在字面上执行 ifcfg-*。 仅排除这些扩展:.old
、.orig
、.rpmnew
、.rpmorig
和.rpmsave
。
2.8. 其它资源
man(1)
man page - 描述 man page 以及如何找到它们。NetworkManager(8)man
page - 描述网络管理守护进程。NetworkManager.conf(5)
手册页 - 描述NetworkManager
配置文件。/usr/share/doc/initscripts-版本/sysconfig.txt
- 描述ifcfg
配置文件及其指令,如传统网络服务所理解。/usr/share/doc/initscripts-版本/examples/networking/
- 包含示例配置文件的目录。ifcfg(8)手册页
- 简要描述 ifcfg 命令.
第 3 章 配置 IP 网络
3.1. 选择网络配置方法
- 要使用 NetworkManager 配置网络接口,请使用以下工具之一:
- 文本用户界面工具 nmtui。如需了解更多详细信息,请参阅 第 3.2 节 “使用 nmtui 配置 IP 网络”。
- 命令行工具 nmcli。如需了解更多详细信息,请参阅 第 3.3 节 “使用 nmcli 配置 IP 网络”。
- 图形用户界面工具 GNOME GUI。如需了解更多详细信息,请参阅 第 3.4 节 “ 使用 GNOME GUI 配置 IP 网络 ”。
- 在不使用 NetworkManager 的情况下配置网络接口:
- 手动编辑
ifcfg
文件。如需了解更多详细信息,请参阅 第 3.5 节 “使用 ifcfg 文件配置 IP 网络”。 - 使用 ip 命令。这可用于分配 IP 地址到接口,但更改在重新启动后不会保留;重新引导后,您将丢失任何更改。如需了解更多详细信息,请参阅 第 3.6 节 “使用 ip 命令配置 IP 网络”。
- 在 root 文件系统不是本地文件系统时配置网络设置 :
- 使用内核命令行。如需了解更多详细信息,请参阅 第 3.7 节 “使用内核命令行配置 IP 网络”。
3.2. 使用 nmtui 配置 IP 网络
先决条件
- nmtui 工具用于终端窗口中。它包含在 NetworkManager-tui 软件包中,但默认情况下不与 NetworkManager 一起安装。要安装 NetworkManager-tui:
~]# yum install NetworkManager-tui
- 要验证 NetworkManager 是否正在运行,请参阅 第 2.3 节 “检查 NetworkManager 的状态”。
流程
- 启动 nmtui 工具:
~]$ nmtui
此时将显示文本用户界面。图 3.1. NetworkManager 文本用户界面起始菜单
[D] - 要导航,请使用箭头键或按 Tab 键前进 ,然后按ShiftTab后退步浏览选项。按 Enter 键选择一个选项。Space bar 切换复选框的状态。
流程
- 选择
Activate a connection
菜单条目。图 3.2. 激活连接
- 选择修改的连接。
在右侧,单击取消激活按钮
。图 3.3. 取消激活修改的连接
再次选择连接并单击激活按钮
。图 3.4. 重新激活修改的连接
nmtui edit
如果没有提供连接名称,则会显示选择菜单。如果提供了连接名称并正确识别,则会出现相关的 Edit 连接屏幕。connection-name
nmtui connect
如果没有提供连接名称,则会显示选择菜单。如果提供连接名称并正确识别,则会激活相关的连接。任何无效的命令都会打印用法消息。connection-name
802.1X
的以太网连接。
3.3. 使用 nmcli 配置 IP 网络
- 对于服务器、无头计算机和终端,nmcli 可用于直接控制 NetworkManager,无需 GUI,包括创建、编辑、启动和停止网络连接,以及查看网络状态。
- 对于脚本,nmcli 支持更适合脚本处理的 terse 输出格式。它是集成网络配置而不是手动管理网络连接的一种方式。
nmcli [OPTIONS] OBJECT { COMMAND | help }其中 OBJECT 可以是以下选项之一:
一般
、联网
、无线
、连接
、设备
、代理
和监控
器。您可以在命令中使用这些选项的任何前缀。例如,nmcli con help、nmcli c help 和nmcli 连接帮助生成相同的输出。
- -t, terse
- 此模式可用于计算机脚本处理,因为您可以看到仅显示值的 terse 输出。
例 3.1. 查看 terse 输出
nmcli -t device ens3:ethernet:connected:Profile 1 lo:loopback:unmanaged:
- -f, 字段
- 此选项指定输出中可以显示哪些字段。例如,NAME,UUID,TYPE,AUTOCONNECT,ACTIVE,DEVICE,STATE.您可以使用一个或多个字段。如果要使用更多,请不要在逗号后使用空格来分隔字段。
例 3.2. 指定输出中的字段
~]$ nmcli -f DEVICE,TYPE device DEVICE TYPE ens3 ethernet lo loopback
甚至更适合编写脚本:~]$ nmcli -t -f DEVICE,TYPE device ens3:ethernet lo:loopback
- -p,相当好。
- 此选项可使 nmcli 生成人类可读的输出。例如,值是一致的,打印标头。
例 3.3. 以用户友善模式查看输出
nmcli -p device ===================== Status of devices ===================== DEVICE TYPE STATE CONNECTION -------------------------------------------------------------- ens3 ethernet connected Profile 1 lo loopback unmanaged --
- -h, help
- 打印帮助信息.
- nmcli help
- 此命令列出可在后续命令中使用的可用选项和对象名称。
- nmcli 对象帮助
- 此命令显示与指定对象相关的可用操作列表。例如:
nmcli c help
3.3.1. nmcli 示例的简短选择
例 3.4. 检查 NetworkManager 的整体状态
~]$ nmcli general status
STATE CONNECTIVITY WIFI-HW WIFI WWAN-HW WWAN
connected full enabled enabled enabled enabled
在 terse 模式中:
~]$ nmcli -t -f STATE general
connected
例 3.5. 查看 NetworkManager 日志状态
~]$ nmcli general logging
LEVEL DOMAINS
INFO PLATFORM,RFKILL,ETHER,WIFI,BT,MB,DHCP4,DHCP6,PPP,WIFI_SCAN,IP4,IP6,A
UTOIP4,DNS,VPN,SHARING,SUPPLICANT,AGENTS,SETTINGS,SUSPEND,CORE,DEVICE,OLPC,
WIMAX,INFINIBAND,FIREWALL,ADSL,BOND,VLAN,BRIDGE,DBUS_PROPS,TEAM,CONCHECK,DC
B,DISPATCH
例 3.6. 查看所有连接
~]$ nmcli connection show
NAME UUID TYPE DEVICE
Profile 1 db1060e9-c164-476f-b2b5-caec62dc1b05 ethernet ens3
ens3 aaf6eb56-73e5-4746-9037-eed42caa8a65 ethernet --
例 3.7. 仅查看当前活跃的连接
~]$ nmcli connection show --active
NAME UUID TYPE DEVICE
Profile 1 db1060e9-c164-476f-b2b5-caec62dc1b05 ethernet ens3
例 3.8. 仅查看 NetworkManager 识别的设备及其状态
~]$ nmcli device status
DEVICE TYPE STATE CONNECTION
ens3 ethernet connected Profile 1
lo loopback unmanaged --
nmcli 命令 | 缩写 | |
---|---|---|
nmcli 常规状态 | nmcli g | |
nmcli 常规日志记录 | nmcli g 日志 | |
nmcli 连接显示 | nmcli con show | |
nmcli connection show --active | nmcli con show -a | |
nmcli 设备状态 | nmcli dev |
3.3.2. 使用 nmcli 启动和停止网络接口
nmcli con up id bond0 nmcli con up id port0 nmcli dev disconnect bond0 nmcli dev disconnect ens3
3.3.3. 了解 nmcli 选项
connection.type
- 连接类型。允许的值有: adsl、bond-slave、bridge-slave、bridge-slave、bluetooth、cdma、以太网、gsm、infiniband、olpc-mesh、team、team-slave、vlan、wifi、wimax。每一连接类型具有特定于类型的命令选项。您可以在 nmcli(1) man page 中看到
TYPE_SPECIFIC_OPTIONS
列表。例如:gsm
连接需要在apn
中指定的接入点名称。nmcli c add connection.type gsm apn access_point_name
Wifi
设备需要在ssid
中指定的服务集标识符。nmcli c add connection.type wifi ssid My identifier
connection.interface-name
- 与连接相关的设备名称。
nmcli con add connection.interface-name enp1s0 type ethernet
connection.id
- 用于连接配置集的名称。如果没有指定连接名称,将按如下方式生成一个连接名称:
connection.type -connection.interface-name
connection.id
是 连接配置集 的名称,不应与表示设备(wlp61s0
、ens3
、em1
)的接口名称混淆。但是,用户可以在接口后命名连接,但它们不是同一事物。个设备可以有多个连接配置集。这对于移动设备或在不同设备之间来回切换网络电缆特别有用。根据需要创建不同的配置集并将它们应用到接口,而不是编辑配置。id
选项还引用连接配置集名称。
show
、up
和down
)的最重要选项有:
id
- 用户分配给连接配置集的身份字符串。id 可用于 nmcli 连接命令来识别连接。命令输出中的 NAME 字段始终表示连接 ID。它引用了 con-name 执行的相同连接配置集名称。
uuid
- 系统分配给连接配置集的唯一标识字符串。可以在 nmcli 连接 命令中使用
uuid
来识别连接。
3.3.4. 使用 nmcli Interactive Connection Editor
~]$ nmcli con edit
系统将提示您从显示的列表中输入有效的连接类型。输入连接类型后,您将放置在 nmcli 提示符下。如果您熟悉连接类型,您可以在 nmcli con edit 命令中添加有效的连接类型选项
,并直接转到 nmcli 提示符。格式用于编辑现有连接配置集: nmcli con edit [id | uuid | path] ID用于编辑新的连接配置集:
nmcli con edit [type new-connection-type] [con-name new-connection-name]
describe setting.property,例如:
nmcli> describe team.config
3.3.5. 使用 nmcli 创建和修改连接配置集
nmcli c add {ARGUMENTS}
- 属性名称
- NetworkManager 用于在内部描述连接的名称。最重要的是:
- connection.type
nmcli c add connection.type
bond
- connection.interface-name
nmcli c add connection.interface-name
enp1s0
- connection.id
nmcli c add connection.id
"My Connection"
有关属性及其设置的更多信息,请参阅nm-settings(5)
man page。
- 别名名称
- 内部转换为属性的人类可读名称。最常用的是:
- type( connection.type 属性)
nmcli c add type
bond
- ifname( connection.interface-name 属性)
nmcli c add ifname
enp1s0
- con-name( connection.id 属性)
nmcli c add con-name
"My Connection"
nmcli
版本中,要使用 别名
创建所需的连接。例如,ifname
enp1s0 和 con-name
My Connection。可以使用以下格式的命令: nmcli c add type ethernet ifname enp1s0 con-name "My Connection"
属性名称和
别名
都可以互换使用。以下示例都是有效且等同的: nmcli c add type ethernet ifname enp1s0 con-name "My Connection" ethernet.mtu 1600
nmcli c add connection.type ethernet ifname enp1s0 con-name "My Connection" ethernet.mtu 1600
nmcli c add connection.type ethernet connection.interface-name enps1s0 connection.id "My Connection" ethernet.mtu 1600
type
参数适用于所有连接类型,if name
是 bond
、team
、bridge
和 vlan
以外的所有类型。
- type type_name
- 连接类型.例如:
nmcli c add type
bond
- ifname interface_name
- 要绑定连接的接口。例如:
nmcli c add ifname interface_name type ethernet
nmcli c modify
connection.id
从 My Connection 改为 My favorite 连接,并将 connection
.interface-name 改为
enp1s0
,请按如下方式发出该命令: nmcli c modify "My Connection" connection.id "My favorite connection" connection.interface-name enp1s0
属性名称
。别名
仅用于兼容性原因。
nmcli c modify "My favorite connection" ethernet.mtu 1600
nmcli con up con-name
例如:
nmcli con up My-favorite-connection
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/16)
3.3.6. 使用 nmcli 连接到网络
~]$ nmcli con show
NAME UUID TYPE DEVICE
Auto Ethernet 9b7f2511-5432-40ae-b091-af2457dfd988 802-3-ethernet --
ens3 fb157a65-ad32-47ed-858c-102a48e064a2 802-3-ethernet ens3
MyWiFi 91451385-4eb8-4080-8b82-720aab8328dd 802-11-wireless wlp61s0
请注意,输出中的 NAME
字段始终表示连接 ID(名称)。它不是接口名称,即使它可能看起来相同。在上面显示的第二个连接中,NAME 字段中的 ens3
是用户提供给应用到接口的配置集的连接 ID ens3.在显示的最后一个连接中,用户已将连接 ID MyWiFi
分配给接口 wlp61s0.
~]$ nmcli device status
DEVICE TYPE STATE CONNECTION
ens3 ethernet disconnected --
ens9 ethernet disconnected --
lo loopback unmanaged --
3.3.7. 使用 nmcli 添加和配置动态以太网连接
添加动态以太网连接
IP
配置添加以太网配置配置集,允许 DHCP
分配网络配置: nmcli connection add type ethernet con-name connection-name ifname interface-name
~]$ nmcli con add type ethernet con-name my-office ifname ens3
Connection 'my-office' (fb157a65-ad32-47ed-858c-102a48e064a2) successfully added.
~]$ nmcli con up my-office
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/5)
检查设备和连接的状态:
~]$ nmcli device status
DEVICE TYPE STATE CONNECTION
ens3 ethernet connected my-office
ens9 ethernet disconnected --
lo loopback unmanaged --
配置动态以太网连接
DHCP
服务器,请修改 dhcp-hostname
属性:
~]$ nmcli con modify my-office my-office ipv4.dhcp-hostname host-name ipv6.dhcp-hostname host-name
IPv4
客户端 ID 更改为 DHCP
服务器,请修改 dhcp-client-id
属性:
~]$ nmcli con modify my-office my-office ipv4.dhcp-client-id client-ID-string
IPv6
没有 dhcp-client-id
属性,dhclient 为 IPv6
创建标识符。详情请查看 thedhclient(8)
手册页。
DHCP
服务器发送到主机的 DNS
服务器,修改 ignore-auto-dns
属性:
~]$ nmcli con modify my-office my-office ipv4.ignore-auto-dns yes ipv6.ignore-auto-dns yes
nm-settings(5)
man page。
例 3.9. 使用交互编辑器配置动态以太网连接
~]$ nmcli con edit type ethernet con-name ens3
===| nmcli interactive connection editor |===
Adding a new '802-3-ethernet' connection
Type 'help' or '?' for available commands.
Type 'describe [<setting>.<prop>]' for detailed property description.
You may edit the following settings: connection, 802-3-ethernet (ethernet), 802-1x, ipv4, ipv6, dcb
nmcli> describe ipv4.method
=== [method] ===
[NM property description]
IPv4 configuration method. If 'auto' is specified then the appropriate automatic method (DHCP, PPP, etc) is used for the interface and most other properties can be left unset. If 'link-local' is specified, then a link-local address in the 169.254/16 range will be assigned to the interface. If 'manual' is specified, static IP addressing is used and at least one IP address must be given in the 'addresses' property. If 'shared' is specified (indicating that this connection will provide network access to other computers) then the interface is assigned an address in the 10.42.x.1/24 range and a DHCP and forwarding DNS server are started, and the interface is NAT-ed to the current default network connection. 'disabled' means IPv4 will not be used on this connection. This property must be set.
nmcli> set ipv4.method auto
nmcli> save
Saving the connection with 'autoconnect=yes'. That might result in an immediate activation of the connection.
Do you still want to save? [yes] yes
Connection 'ens3' (090b61f7-540f-4dd6-bf1f-a905831fc287) successfully saved.
nmcli> quit
~]$
默认操作是将连接配置集保存为持久。如果需要,通过 save 临时命令,配置集只能保存在内存中,直到下次重启为止。
3.3.8. 使用 nmcli 添加和配置静态以太网连接
添加静态以太网连接
IPv4
配置添加以太网连接: nmcli connection add type ethernet con-name connection-name ifname interface-name ip4 address gw4 address
IPv6
地址和网关信息可使用 ip6
和gw6 选项添加
。
IPv4
地址和网关的静态以太网连接:
~]$ nmcli con add type ethernet con-name test-lab ifname ens9 ip4 10.10.10.10/24 \ gw4 10.10.10.254另外,还可为设备指定
IPv6
地址和网关:
~]$ nmcli con add type ethernet con-name test-lab ifname ens9 ip4 10.10.10.10/24 \ gw4 10.10.10.254 ip6 abbe::cafe gw6 2001:db8::1 Connection 'test-lab' (05abfd5e-324e-4461-844e-8501ba704773) successfully added.
IPv4
DNS
服务器地址:
~]$ nmcli con mod test-lab ipv4.dns "8.8.8.8 8.8.4.4"
请注意,这将取代任何先前设置的 DNS
服务器。设置两个 IPv6
DNS
服务器地址:
~]$ nmcli con mod test-lab ipv6.dns "2001:4860:4860::8888 2001:4860:4860::8844"
请注意,这将取代任何先前设置的 DNS
服务器。另外,要将额外的 DNS
服务器添加到任何先前设置中,请使用 +
前缀:
~]$ nmcli con mod test-lab +ipv4.dns "8.8.8.8 8.8.4.4"
~]$ nmcli con mod test-lab +ipv6.dns "2001:4860:4860::8888 2001:4860:4860::8844"
~]$ nmcli con up test-lab ifname ens9
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/6)
检查设备和连接的状态:
~]$ nmcli device status
DEVICE TYPE STATE CONNECTION
ens3 ethernet connected my-office
ens9 ethernet connected test-lab
lo loopback unmanaged --
~]$ nmcli -p con show test-lab =============================================================================== Connection profile details (test-lab) =============================================================================== connection.id: test-lab connection.uuid: 05abfd5e-324e-4461-844e-8501ba704773 connection.interface-name: ens9 connection.type: 802-3-ethernet connection.autoconnect: yes connection.timestamp: 1410428968 connection.read-only: no connection.permissions: connection.zone: -- connection.master: -- connection.slave-type: -- connection.secondaries: connection.gateway-ping-timeout: 0 [output truncated]使用
-p, --pretty
选项会在输出中添加一个标题横幅和部分中断。
例 3.10. 使用交互编辑器配置静态以太网连接
~]$ nmcli con edit type ethernet con-name ens3
===| nmcli interactive connection editor |===
Adding a new '802-3-ethernet' connection
Type 'help' or '?' for available commands.
Type 'describe [>setting<.>prop<]' for detailed property description.
You may edit the following settings: connection, 802-3-ethernet (ethernet), 802-1x, ipv4, ipv6, dcb
nmcli> set ipv4.addresses 192.168.122.88/24
Do you also want to set 'ipv4.method' to 'manual'? [yes]: yes
nmcli>
nmcli> save temporary
Saving the connection with 'autoconnect=yes'. That might result in an immediate activation of the connection.
Do you still want to save? [yes] no
nmcli> save
Saving the connection with 'autoconnect=yes'. That might result in an immediate activation of the connection.
Do you still want to save? [yes] yes
Connection 'ens3' (704a5666-8cbd-4d89-b5f9-fa65a3dbc916) successfully saved.
nmcli> quit
~]$
默认操作是将连接配置集保存为持久。如果需要,通过 save 临时命令,配置集只能保存在内存中,直到下次重启为止。
connection.autoconnect
设为 yes
。NetworkManager 还会将设置写出到 /etc/sysconfig/network-scripts/ifcfg-my-office
,其中对应的 BOOTPROTO 将设置为 none
,ONBOOT 设为 yes
。
3.3.9. 使用 nmcli 将配置集锁定到特定设备
nmcli connection add type ethernet con-name connection-name ifname interface-name,要使配置集可用于所有兼容以太网接口:
nmcli connection add type ethernet con-name connection-name ifname "*"请注意,即使您不想设置特定的接口,也必须使用
ifname
参数。使用通配符 *
指定配置集可用于任何兼容的设备。
nmcli connection add type ethernet con-name "connection-name" ifname "*" mac 00:00:5E:00:53:00
3.3.10. 使用 nmcli 添加 Wi-Fi 连接
~]$ nmcli dev wifi list
SSID MODE CHAN RATE SIGNAL BARS SECURITY
FedoraTest Infra 11 54 MB/s 98 ▂▄▆█ WPA1
Red Hat Guest Infra 6 54 MB/s 97 ▂▄▆█ WPA2
Red Hat Infra 6 54 MB/s 77 ▂▄▆_ WPA2 802.1X
* Red Hat Infra 40 54 MB/s 66 ▂▄▆_ WPA2 802.1X
VoIP Infra 1 54 MB/s 32 ▂▄__ WEP
MyCafe Infra 11 54 MB/s 39 ▂▄__ WPA2
IP
配置创建 Wi-Fi 连接配置集,但允许自动 DNS
地址分配:
~]$ nmcli con add con-name MyCafe ifname wlp61s0 type wifi ssid MyCafe \ ip4 192.168.100.101/24 gw4 192.168.100.1设置 WPA2 密码,如 “caffeine” :
~]$ nmcli con modify MyCafe wifi-sec.key-mgmt wpa-psk ~]$ nmcli con modify MyCafe wifi-sec.psk caffeine有关密码安全性的信息,请参阅Red Hat Enterprise Linux 7 安全指南。
~]$ nmcli radio wifi [on | off ]
使用 nmcli 更改特定属性
mtu
:
~]$ nmcli connection show id 'MyCafe' | grep mtu
802-11-wireless.mtu: auto
更改设置的属性:
~]$ nmcli connection modify id 'MyCafe' 802-11-wireless.mtu 1350
验证更改:
~]$ nmcli connection show id 'MyCafe' | grep mtu
802-11-wireless.mtu: 1350
802-3-ethernet
和 802-11-wireless
等参数,mtu
作为设置的属性。有关属性及其设置的更多信息,请参阅 nm-settings(5)
man page。
3.3.11. 将 NetworkManager 配置为 Ignore Certain 设备
lo
(环回)设备以外的所有设备。但是,您可以将某些设备设置为非受管设备,以配置 NetworkManager 忽略这些设备。使用这个设置,您可以手动管理这些设备,例如使用脚本。
3.3.11.1. 将设备永久配置为 NetworkManager 中的非受管设备
enp1s0
接口设置为 NetworkManager 中的非受管接口。
流程
- 可选:显示要标识您要设置为非受管设备的设备列表 :
# nmcli device status DEVICE TYPE STATE CONNECTION enp1s0 ethernet disconnected -- ...
- 使用以下内容创建
/etc/NetworkManager/conf.d/99-unmanaged-devices.conf
文件:[keyfile] unmanaged-devices=interface-name:enp1s0
要将多个设备设置为非受管设备,请使用分号分隔unmanaged-devices
参数中的条目:[keyfile] unmanaged-devices=interface-name:interface_1;interface-name:interface_2;...
- 重新载入
NetworkManager
服务:# systemctl reload NetworkManager
验证步骤
- 显示设备列表:
# nmcli device status DEVICE TYPE STATE CONNECTION enp1s0 ethernet unmanaged -- ...
enp1s0
设备旁边的非受管状态表示 NetworkManager 不管理此设备。
其它资源
3.3.11.2. 将设备临时配置为 NetworkManager 中的非受管设备
enp1s0
接口设置为 NetworkManager 中的非受管接口。
流程
- 可选:显示要标识您要设置为非受管设备的设备列表 :
# nmcli device status DEVICE TYPE STATE CONNECTION enp1s0 ethernet disconnected -- ...
- 将
enp1s0
设备设置为非受管状态 :# nmcli device set enp1s0 managed no
验证步骤
- 显示设备列表:
# nmcli device status DEVICE TYPE STATE CONNECTION enp1s0 ethernet unmanaged -- ...
enp1s0
设备旁边的非受管状态表示 NetworkManager 不管理此设备。
其它资源
3.4. 使用 GNOME GUI 配置 IP 网络
- GNOME control-center 应用程序
- GNOME nm-connection-editor 应用程序
3.4.1. 使用 control-center GUI 连接到网络
- 按 Super 键进入 Activities Overview,键入 Settings,然后按 Enter 键。然后,选择左侧的网络
选项卡
,并显示 网络设置 工具。继续 “使用 control-center 配置新连接”一节。 - 单击屏幕右上角的 GNOME Shell 网络连接图标,以打开其菜单。
图 3.5. 使用 control-center 应用进行网络配置
[D]
- 您当前连接的分类网络列表(如 Wired 和 Wi-Fi)。
- NetworkManager 检测到的所有可用网络的列表。
- 连接任何已配置的虚拟专用网络(VPN)的选项.和
- 选择 Network Settings 菜单条目的选项。
3.4.2. 使用 GUI 配置新连接并编辑现有连接
- GNOME control-center 应用程序
- GNOME nm-connection-editor 应用程序
3.4.2.1. 使用 control-center 配置新的和编辑现有连接
使用 control-center 配置新连接
- 按 Super 键进入 Activities Overview,键入 Settings,然后按 Enter 键。
然后,选择左侧的网络选项卡
。Network settings 工具会出现在右侧菜单中:图 3.6. 打开 Network Settings 窗口
- 单击加号按钮来添加新连接。配置:
- 有线连接,单击 Wired 条目旁边的加号按钮,再继续 第 3.4.6 节 “使用 GUI 配置连线(以太网)连接”。
使用 control-center 编辑现有连接
IP
寻址、DNS
和路由配置。
图 3.7. 使用网络连接详情窗口配置网络
[D]
3.4.2.2. 使用 nm-connection-editor 配置新的和编辑现有连接
使用 nm-connection-editor 配置新连接
流程
- 在终端中输入
nm-connection-editor
:~]$ nm-connection-editor
这时将显示Network Connections
窗口。 - 点击加号按钮选择一个连接类型:
图 3.8. 使用 nm-connection-editor 添加连接类型
图 3.9. 使用 nm-connection-editor 选择连接类型
创建并配置:
使用 nm-connection-editor 编辑现有连接
3.4.3. 使用 nm-connection-editor 的通用配置选项
nm-connection-editor
实用程序,请按照以下步骤操作最多连接类型(以太网、wifi、移动宽带、DSL)的五个常用配置选项:
流程
- 在终端中输入
nm-connection-editor
:~]$ nm-connection-editor
这时将显示Network Connections
窗口。点击加号按钮选择连接类型或 gear wheel 图标以编辑现有连接。 - 在 Editing 对话框中选择 General 选项卡:
图 3.10. nm-connection-editor 中的配置选项
- 连接名称 - 输入您的网络连接描述性名称。此名称用于在 Network 窗口的菜单中列出此连接。
- 自动激活的连接优先级 - 如果连接被设置为自动连接,则激活该数字(默认为
0
)。数值越高,表示优先级更高。 - 当这个网络可用时自动连接到这个网络 - 如果您希望 NetworkManager 在可用时自动连接到这个连接,请选择这个框。如需更多信息,请参阅 “使用 control-center 编辑现有连接”一节。
- 所有用户可以连接到此网络 - 选择此框可创建系统上所有用户可用的连接。更改此设置可能需要 root 特权。详情请查看 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
- 使用这个连接时自动连接到 VPN - 如果您希望 NetworkManager 在有可用时自动连接到 VPN 连接,请选择这个框。从下拉菜单中选择 VPN。
- firewall Zone - 从下拉菜单中选择防火墙区域。有关防火墙区域的更多信息,请参阅Red Hat Enterprise Linux 7 安全指南。
3.4.4. 使用 GUI 自动连接到网络
- GNOME control-center 应用程序
- GNOME nm-connection-editor 应用程序
3.4.4.1. 使用 control-center 自动连接到网络
流程
- 按 Super 键进入 Activities Overview,键入 Settings,然后按 Enter 键。然后,选择左侧的网络选项卡。Network settings 工具会出现在右侧菜单中,请参阅 “使用 control-center 配置新连接”一节。
- 从右侧菜单中选择网络接口。
- 在右侧菜单点击连接配置集的 gear wheel 图标。这时将显示网络详细信息窗口。
- 选择 Details 菜单条目,请参阅 “使用 control-center 编辑现有连接”一节。
- 选择"连接"自动会导致 NetworkManager 每当 NetworkManager 检测到可用时自动连接到连接。如果您不希望 NetworkManager 自动连接,请清除复选框。如果复选框已清除,您必须在网络连接图标的菜单中手动选择该连接,使其连接。
3.4.4.2. 使用 nm-connection-editor 自动连接到网络
选中 Automatically connect to this network
。
3.4.5. 使用 GUI 管理系统范围以及专用连接配置集
有关连接设置
权限属性的更多信息
,请参阅 nm-settings(5)
man page。 您可以使用以下图形用户界面工具控制对连接配置集的访问:
- nm-connection-editor 应用程序
- control-center 应用程序
3.4.5.1. 使用 nm-connection-editor 管理连接配置集的权限
3.4.5.2. 使用 control-center 管理连接配置集的权限
Details
窗口中选择" 可供其他用户 使用"复选框。
user-em2
,并选择了 Connect Automatically 复选框 ,但是其他未选择的用户可使用 Make,则在引导时无法使用连接。
- 清除 Make available to other users 复选框,该复选框将连接更改为仅可由用户进行更改才可修改和使用。
- 使用 polkit 框架根据每个用户限制常规网络操作的权限。
polkit 的更多信息
,请参阅 polkit 手册页。
3.4.6. 使用 GUI 配置连线(以太网)连接
- control-center 应用程序
- nm-connection-editor 应用程序
3.4.6.1. 使用 control-center 配置 Wired Connection
流程
- 按 Super 键进入 Activities Overview,键入 Settings,然后按 Enter 键。然后,选择左侧的
Network
菜单条目,并显示 网络设置 工具,请参阅 “使用 control-center 配置新连接”一节。 - 如果还没有突出显示,请选择 Wired 网络接口。默认情况下,系统会创建和配置一个名为 Wired 的有线连接配置集。配置文件是可应用于接口的设置的命名集合。可以为接口创建多个配置集并根据需要应用。默认配置集无法删除,但可以更改其设置。
- 点击 gear wheel 图标编辑默认 Wired 配置集。
基本配置选项
图 3.11. Wired Connection 的基本配置选项
- Name - 输入您的网络连接描述性名称。此名称将用于在 Network 窗口的菜单中列出此连接。
- MAC Address - 选择此配置集必须应用到的接口的 MAC 地址。
- 克隆地址 - 如果需要,请输入要使用的不同 MAC 地址。
- MTU - 如果需要,请输入要使用的特定最大传输单元 (MTU)。MTU 值表示链路层传输的最大数据包的字节大小。这个值默认为
1500
,通常不需要指定或更改。
生成更多连线配置
- 或者
保存您的新(或修改的)连线连接
创建新 Wired 连接
3.4.6.2. 使用 nm-connection-editor 配置 Wired Connection
- 在终端中输入 nm-connection-editor。
~]$ nm-connection-editor
这时将显示Network Connections
窗口。 - 选择您要编辑的以太网连接并点击 gear wheel 图标:
图 3.12. 编辑有线连接
此时将显示编辑
对话框。- 要自动连接到网络并限制连接,请点击
General
选项卡,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。 - 要配置网络设置,请点击
以太网
选项卡,请参阅 “使用 nm-connection-editor 配置 802.3 链路设置”一节。 - 要为有线连接配置 802.1X 安全性,点
802.1X 安全
选项卡,请参阅 第 5.2.4 节 “使用 nm-connection-editor 为 Wired 配置 802.1X 安全性”。 - 要配置 IPV4 设置,请点击
IPV4 Settings
选项卡,请参阅 “使用 nm-connection-editor 设置 IPV4 的方法”一节。 - 要配置 IPV6 设置,请点击
IPV6 Settings
选项卡,请参阅 第 5.5 节 “配置 IPv6 设置”。
3.4.7. 使用 GUI 配置 Wi-Fi 连接
Wi-Fi
(也称为无线或者 802.11a/b/g/n)到接入点的连接。Access Point 是一个允许无线设备连接到网络的设备。
快速连接到可用接入点
流程
- 点击网络连接图标激活网络连接图标的菜单,请参阅 第 3.4.1 节 “使用 control-center GUI 连接到网络”。
- 在 Wi-Fi 网络列表中,找到接入点的 Service Set Identifier (SSID)。
- 单击网络的 SSID。挂锁符号表示接入点需要身份验证。如果访问点受到保护,对话框会提示您输入身份验证密钥或密码。NetworkManager 尝试自动检测接入点使用的安全性类型。如果存在多种可能性,NetworkManager 会猜测安全类型,并将其显示在 Wi-Fi 安全下拉菜单中。
- 对于 WPA-PSK 安全(带有密码的 WPA)而言,无需选择。
- 对于 WPA Enterprise(802.1X),您必须特别选择安全性,因为无法自动检测安全性。请注意,如果您不确定,请依次尝试分别连接到每种类型。
- 在"密码"字段中输入密钥或密码短语。某些密码类型(如 40 位 WEP 或 128 位 WPA 密钥)无效,除非它们具有必要长度。连接按钮将保持不活动状态,直到您输入了所选安全类型所需的长度的密钥。要了解更多有关无线安全性的信息,请参阅 第 5.2 节 “配置 802.1X 安全性”。
连接到 Hidden Wi-Fi 网络
流程
- 按 Super 键进入 Activities Overview,键入 Settings,然后按 Enter 键。然后,选择左侧
的 Wi-Fi
菜单条目。 - 选择 Connect to Hidden Network。有两个选项:
- 如果您在以下前连接到隐藏网络:
- 使用连接下拉菜单选择网络。
- 点。
- 如果没有,请按以下方法操作:
- 连接下拉列表保留为 新建。
- 输入隐藏网络的 SSID。
- 选择其 Wi-Fi 安全方法。
- 输入正确的身份验证 secret。
- 点。
配置新的 Wi-Fi 连接
流程
- 选择 Settings 的 Wi-Fi 菜单条目。
- 点击您要连接到的 Wi-Fi 连接名称(默认情况下,与 SSID 相同)。
- 如果 SSID 没有范围,请参阅 “连接到 Hidden Wi-Fi 网络”一节。
- 如果 SSID 的范围不同,点右侧菜单中的
Wi-Fi
连接配置集。padlock 符号表示需要密钥或密码。如果需要,输入验证详情。
编辑现有 Wi-Fi 连接
流程
- 按 Super 键进入 Activities Overview,键入 Settings 并按 Enter。
- 从左侧的菜单条目中选择 Wi-Fi。
- 选择您要编辑的 Wi-Fi 连接名称右侧的 gear wheel 图标,并会出现编辑连接对话框。请注意,如果网络当前不在范围内,请单击 History 以显示旧的连接。Details 窗口显示连接详情。
Wi-Fi 连接的基本配置选项
图 3.13. Wi-Fi 连接的基本配置选项
- SSID
- 接入点(AP) 的服务集合标识符 (SSID)。
- BSSID
- 基本服务集合标识符 (BSSID) 是您在基础架构模式中连接的特定无线访问点的 MAC 地址(也称为硬件地址 )。默认情况下,此字段为空白,您可以通过 SSID 连接到无线访问点,而无需指定 BSSID。如果指定了 BSSID,它将强制系统只关联到特定的接入点。对于临时网络,在创建 ad-hoc 网络时,BSSID 由 mac80211 子系统随机生成。NetworkManager不显示它
- MAC 地址
- 选择要使用的 Wi-Fi 接口的 MAC 地址(也称为硬件地址 )。单个系统可以连接一个或多个无线网络适配器。因此,MAC 地址字段允许您将特定的无线适配器与特定连接 (或连接)关联。
- 克隆的地址
- 用于代替实际硬件地址的克隆 MAC 地址。保留空白,除非需要。
- 提供给其他用户 - 选择此框可创建可供系统上的所有用户使用的连接。更改此设置可能需要 root 特权。详情请查看 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
进行进一步的 Wi-Fi 配置
- 或者
保存您的新(或修改的)连接
3.4.8. 使用 GUI 配置 VPN 连接
IPsec
是创建 VPN 的首选方法。Libreswan 是 VPN 的开源用户空间 IPsec
实现。使用命令行配置 IPsec
VPN 信息包括在Red Hat Enterprise Linux 7 安全指南中。
3.4.8.1. 使用 control-center 建立 VPN 连接
IPsec
是在 Red Hat Enterprise Linux 7 中创建 VPN 的首选方法。如需更多信息,请参阅 第 3.4.8 节 “使用 GUI 配置 VPN 连接”。
root
用户身份运行以下命令:
~]# yum install NetworkManager-libreswan-gnome
- 它为路由和验证目的添加了身份验证标头 ;
- 它加密数据包数据;以及,
- 它根据封装安全负载(ESP)协议将数据包含在数据包中,其中包括解密和处理指令。
添加新 IPsec VPN 连接
流程
- 按 Super 键进入 Activities Overview,键入 Settings 并按 Enter。然后,选择 Network 菜单条目,并显示网络设置工具,请参阅 “使用 control-center 配置新连接”一节。
- 点 VPN 条目中的加号按钮。
- 此时会出现 Add VPN 窗口。 对于手动配置,请选择 基于 IPsec 的 VPN。
图 3.14. 在 IPsec 模式上配置 VPN
- 在
Identity
configuration 表单中,您可以在General
和Advanced
部分中指定字段:图 3.15. General 和 Advanced 部分
- 在
General
部分,您可以指定:
- gateway
- 远程 VPN 网关的名称或
IP 地址
。 - 用户名
- 如果需要,输入与 VPN 用户身份关联的用户名进行身份验证。
- 用户密码
- 如果需要,输入与 VPN 用户身份关联的密码进行验证。
- 组名称
- 在远程网关中配置的 VPN 组的名称。如果为空,则使用 IKEv1 主模式,而不是默认的 Aggressive 模式。
- Secret
- 它是预共享的密钥,用于在用户身份验证之前初始化加密。如果需要,请输入与组名称关联的密码。
- 以下配置设置位于
Advanced
部分:
- phase1 算法
- 如果需要,输入用来验证和设置加密频道的算法。
- phase2 算法
- 如果需要,请输入用于
IPsec
协商的算法。 - 域
- 如果需要,输入域名。
编辑现有 VPN 连接
流程
- 按 Super 键进入 Activities Overview,键入 Settings 并按 Enter。然后,选择 Network 菜单条目,并显示网络设置工具,请参阅 “使用 control-center 配置新连接”一节。
- 选择您要编辑的 VPN 连接并点击 gear wheel 图标并编辑
General
和Advanced
部分,请参阅 第 3.4.8.1 节 “使用 control-center 建立 VPN 连接”。
保存您的新(或修改)连接并创建进一步配置
3.4.8.2. 使用 nm-connection-editor 配置 VPN 连接
流程
- 在终端中输入 nm-connection-editor。这时将显示 Network Connections 窗口,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。
- 单击加号按钮。此时会打开 Choose a Connection Type 菜单。
- 从菜单条目中选择,
基于 IPsec 的 VPN
选项。
3.4.9. 使用 GUI 配置移动带宽连接
- 2G - GPRS(通用封包广播服务 )、EDGE(GSM Evolution 的增强数据率 )或 CDMA(代码划分多访问)。
- 3G - UMTS(通用移动电信系统 )、HSPA(高分组访问 )或 EVDO(仅 EVolution 数据)。
3.4.9.1. 使用 nm-connection-editor 配置移动带宽连接
添加新移动带宽连接
流程
- 在终端中输入 nm-connection-editor。这时将显示 Network Connections 窗口,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。
- 单击加号按钮。此时会打开 Choose a Connection Type 菜单。
- 选择菜单条目。
- 单击 Set up a Mobile Broadband Connection 助理。
- 在创建此移动宽带设备的连接下,选择与连接一起使用的 2G 或 3G 功能设备。如果下拉菜单不活跃,这表明系统无法检测到能够移动宽带的设备。在这种情况下,点击 Cancel,请确保您有一个支持移动宽带的设备被计算机附加和识别,然后重试此过程。单击 Continue 按钮。
- 从列表中选择您的服务提供商所在的国家,然后单击 Continue 按钮。
- 从列表中选择您的供应商或手动输入您的供应商。单击 Continue 按钮。
- 从下拉菜单中选择您的付款计划,并确认 Access Point Name (APN)正确无误。单击 Continue 按钮。
- 检查并确认设置,然后单击应用按钮。
- 通过参考编辑移动宽带特定设置 “配置 Mobile Broadband 选项卡”一节
编辑现有移动带宽连接
流程
- 在终端中输入 nm-connection-editor。这时将显示 Network Connections 窗口。
- 选择 Mobile Broadband 选项卡。
- 选择您要编辑的连接并点击 gear wheel 图标。如需更多信息,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。
- 通过参考编辑移动宽带特定设置 “配置 Mobile Broadband 选项卡”一节
配置 Mobile Broadband 选项卡
- 数字
- 与基于 GSM 的移动宽带网络建立 PPP 连接的数字。这个字段可以在首次安装宽带设备时自动填充。通常您可以将此字段留空并输入 APN。
- username
- 输入用于通过网络进行身份验证的用户名。有些提供商不提供用户名,或者在连接网络时接受任何用户名。
- 密码
- 输入用于通过网络进行身份验证的密码。有些提供程序不提供密码或接受任何密码。
- APN
- 输入用于建立与基于 GSM 网络的连接的接入点名称 (APN)。为连接输入正确的 APN 非常重要,因为它通常会决定:
- 如何为用户的网络使用计费;
- 用户是可以访问互联网、内部网还是子网。
- 网络 ID
- 输入网络 ID 会导致 NetworkManager 强制设备只注册到特定网络。这可用于确保连接不会在无法直接控制漫游时轮转。
- 类型
- any - 默认值保留 modem 以选择最快的网络。3G(UMTS/HSPA) - 强制连接仅使用 3G 网络技术。2G(GPRS/EDGE) - 强制连接仅使用 2G 网络技术。首选 3G(UMTS/HSPA) - 首先尝试使用 3G 技术(如 HSPA 或 UMTS)进行连接,并且仅在失败时回退到 GPRS 或 EDGE。首选 2G(GPRS/EDGE) - 首先尝试使用 2G 技术(如 GPRS 或 EDGE)进行连接,并且仅在出现故障时回退到 HSPA 或 UMTS。
- 如果 home 网络不可用,允许轮转
- 如果您希望 NetworkManager 终止连接,而不是从 home 网络转换到漫游网络,请取消选中此框,从而避免可能的漫游收费。如果选中此框,NetworkManager 会尝试通过从 home 网络转换到漫游网络来维持良好的连接,反之亦然。
- PIN
- 如果您设备的 SIM(订阅者身份模块 )被锁定为 PIN(个人识别号 ),请输入 PIN,以便 NetworkManager 可以解锁该设备。如果需要 PIN 才能将该设备用于任何目的,NetworkManager 必须解锁 SIM。
APN
、网络 ID 或
Type
选项。
保存您的新(或修改)连接并创建进一步配置
3.4.10. 使用 GUI 配置 DSL 连接
3.4.10.1. 使用 nm-connection-editor 配置 DSL 连接
添加新 DSL 连接
流程
- 在终端中输入 nm-connection-editor。这时将显示 Network Connections 窗口,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。
- 单击加号按钮。
- 此时将显示 Choose a Connection Type 列表。
- 选择"按钮。
- 此时将显示 Editing DSL Connection 1 窗口。
编辑现有 DSL 连接
流程
- 在终端中输入 nm-connection-editor。这时将显示 Network Connections 窗口。
- 选择您要编辑的连接并点击 gear wheel 图标。如需更多信息,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。
配置 DSL 选项卡
- username
- 输入用于与服务提供商进行身份验证的用户名。
- 服务
- 除非由服务提供商另有指示,否则留空。
- 密码
- 输入服务提供商提供的密码。
保存您的新(或修改)连接并创建进一步配置
3.5. 使用 ifcfg 文件配置 IP 网络
ifcfg
文件手动配置网络接口。
ifcfg-name ,后缀名称指的是配置文件控制的设备的名称
。按照惯例,ifcfg 文件的后缀与配置文件中
DEVICE 指令提供的字符串相同。
使用 ifcfg 文件配置带有静态网络设置的接口
ifcfg
文件配置带有静态网络设置的接口,请为名为 enp1s0
的接口,在 /etc/sysconfig/network -scripts/ 目录中创建一个名为 ifcfg-
enp1s0
的文件,该文件包含:
- 对于
IPv4
配置DEVICE=enp1s0 BOOTPROTO=none ONBOOT=yes PREFIX=24 IPADDR=10.0.1.27
- 对于
IPv6
配置DEVICE=enp1s0 BOOTPROTO=none ONBOOT=yes IPV6INIT=yes IPV6ADDR=2001:db8::2/48
您不需要指定网络或广播地址,因为这由 ipcalc 自动计算。更多IPv6
ifcfg 配置选项请查看 nm-settings-ifcfg-rh(5) man page。
使用 ifcfg 文件配置带有动态网络设置的接口
ifcfg
文件配置名为 em1 的接口:
- 在
/etc/sysconfig/network-scripts/ 目录中创建一个名为 ifcfg-em1
DEVICE=em1 BOOTPROTO=dhcp ONBOOT=yes
- 要将接口配置为向
DHCP
服务器发送其他主机名,请在ifcfg
文件中添加以下行:DHCP_HOSTNAME=hostname
要将接口配置为将不同的完全限定域名(FQDN)发送到DHCP
服务器,请在ifcfg
文件中添加以下行:DHCP_FQDN=fully.qualified.domain.name
注意在给定的ifcfg
文件中只能使用一个指令(DHCP_HOSTNAME 或 DHCP_FQDN )。如果同时指定了 DHCP_HOSTNAME 和 DHCP_FQDN,则仅使用后者。 - 要将接口配置为使用特定的
DNS
服务器,请在ifcfg
文件中添加以下行:PEERDNS=no DNS1=ip-address DNS2=ip-address
其中 ip-address 是DNS
服务器的地址。这会导致网络服务使用指定的DNS
服务器更新/etc/resolv.conf
。只需要一个DNS
服务器地址,另一个是可选的。 - 要在
ifcfg
文件中配置静态路由,请参阅 第 4.5 节 “在 ifcfg 文件中配置静态路由”。默认情况下,当配置集被设置为通过在接口配置文件中将BOOTPROTO
设置为dhcp
来自动获取地址时,NetworkManager 会调用DHCP
客户端, dhclient。如果需要DHCP
,则会在接口上为每个互联网协议IPv4 和 IPv
启动 todhclient 实例。如果 NetworkManager 没有运行,或者未管理接口,则传统的网络服务将根据需要调用 fordhclient 实例。有关动态 IP 地址的详情,请参考 第 1.2 节 “静态与动态 IP 地址比较”。6
- 应用配置:
- 重新载入更新的连接文件:
# nmcli connection reload
- 重新激活连接:
# nmcli connection up connection_name
3.5.1. 使用 ifcfg 文件管理系统范围以及专用连接配置集
ifcfg
文件中的 USERS
指令对应。如果没有 USERS
指令,则网络配置文件将可供所有用户使用。例如,ifcfg 文件中的以下命令将仅使连接对列出的用户可用
: USERS="joe bob alice"
USERCTL
指令来管理该设备:
- 如果您设置了 yes,则允许非
root
用户控制这个设备。 - 如果没有,则 不允许非
root
用户控制这个设备。
3.6. 使用 ip 命令配置 IP 网络
man ip(8)
页面中。Red Hat Enterprise Linux 7 中的软件包名称为 iproute。如果需要,您可以通过检查其版本号来检查是否安装了 ip 工具程序,如下所示:
~]$ ip -V
ip utility, iproute2-ss130716
ip link set ifname down
IFF_UP
状态的网络接口,并从内核的范围中启用它。这与用于 initscripts 或 NetworkManager 设备的激活状态的 ifup ifname 命令不同。事实上,NetworkManager 始终会设置接口,即使它当前已断开连接。通过 nmcli 工具断开连接设备,不会删除 IFF_UP
标志。这样,NetworkManager 获取有关载波状态的通知。
如果需要持久性时,请使用配置文件(ifcfg
文件)或向脚本添加命令。
IP 地址
,格式如下: ip addr [ add | del ] address dev ifname
使用 ip 命令分配静态地址
IP 地址
,请执行以下操作:
~]# ip address add 10.0.0.3/24 dev enp1s0 You can view the address assignment of a specific device: ~]# ip addr show dev enp1s0 2: enp1s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000 link/ether f0:de:f1:7b:6e:5f brd ff:ff:ff:ff:ff:ff inet 10.0.0.3/24 brd 10.0.0.255 scope global global enp1s0 valid_lft 58682sec preferred_lft 58682sec inet6 fe80::f2de:f1ff:fe7b:6e5f/64 scope link valid_lft forever preferred_lft forever更多示例和命令选项可在
ip-address(8)手册页中找到
。
使用 ip 命令配置多个地址
~]# ip address add 192.168.2.223/24 dev enp1s0 ~]# ip address add 192.168.4.223/24 dev enp1s0 ~]# ip addr 3: enp1s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000 link/ether 52:54:00:fb:77:9e brd ff:ff:ff:ff:ff:ff inet 192.168.2.223/24 scope global enp1s0 inet 192.168.4.223/24 scope global enp1s0
ip(8)手册页
。
3.7. 使用内核命令行配置 IP 网络
- 使用内核命令行中的
ip
选项设置配置:ip<client-IP-number>:[<server-id>]:<gateway-IP-number>:<netmask>:<client-hostname>:<interface>:{dhcp|dhcp6|auto6|on|any|none|off}
例如:DHCP
- DHCP 配置dhpc6
- DHCP IPv6 配置auto6
- 自动 IPv6 配置在任何
- 内核中可用的任何协议(默认)
none
,off
- 无自动配置,静态网络配置
ip=192.168.180.120:192.168.180.100:192.168.180.1:255.255.255.0::enp1s0:off
- 设置名称服务器配置:
nameserver=srv1 [nameserver=srv2 [nameserver=srv3 […]]]
/etc/sysconfig/network-scripts/
文件中的新 ifcfg
文件。
3.8. 使用 IGMP 启用 IP 多播
~]$ ip maddr show dev br0
8: br0
inet 224.0.0.1
inet6 ff02::1
inet6 ff01::1
[output truncated]
MULTICAST
字符串,例如:
~]$ ip link show br0 8: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT qlen 1000 link/ether 6c:0b:84:67:fe:63 brd ff:ff:ff:ff:ff:ff
~]# ip link set multicast off dev br0 ~]$ ip link show br0 8: br0: <BROADCAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT qlen 1000 link/ether 6c:0b:84:67:fe:63 brd ff:ff:ff:ff:ff:ff
MULTICAST
字符串表示多播已被禁用。
~]# ip link set multicast on dev br0 ~]$ ip link show br0 8: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT qlen 1000 link/ether 6c:0b:84:67:fe:63 brd ff:ff:ff:ff:ff:ff
文章和 ip(8)man
page。
/proc/net/igmp
文件:
~]$ cat /proc/net/igmp
默认情况下
,firewalld 中不启用 IGMP。为区启用 IGMP:
~]# firewall-cmd --zone=zone-name --add-protocol=igmp
3.9. 其它资源
安装的文档
- ip(8) man page - 描述 ip 实用程序的命令语法。
- nmcli(1) man page - 描述 NetworkManager 的命令行工具.
- nmcli-examples(5) man page - 提供 nmcli 命令的示例.
- nm-settings(5) man page - 描述 NetworkManager 属性及其设置。
- nm-settings-ifcfg-rh(5) man page - 描述 ifcfg-rh 设置插件.
在线文档
- Red Hat Enterprise Linux 7 安全指南
- 描述基于
IPsec
的 VPN 及其配置。描述使用 DNSSEC 进行身份验证的DNS
查询。 - RFC 1518 - 无类别域间路由(CIDR)
- 描述 CIDR Address Assignment 和 Aggregation 策略,包括可变长度子网。
- RFC 1918 - 专用互联网的地址分配
- 描述保留给私有使用的
IPv4
地址范围。 - RFC 3330 - 特殊使用 IPv4 地址
- 描述互联网编号分配机构(IANA)分配的全局和其他专用
IPv4
地址块。
第 4 章 配置静态路由和默认网关
4.1. 了解路由和网关简介
DHCP
配置时,通常会分配一个网关地址,用于上游网络或互联网。此网关通常称为默认网关,因为如果系统不知道更好的路由(路由表中已存在),则使用该网关。网络管理员通常使用网络中的第一个或最后一个主机 IP 地址作为网关地址
;例如 192.168.10.1 或
192.168.10.254
。不要被代表网络本身的地址混淆;在本示例中,192.168.10.0
或子网的广播地址;在本例中为 192.168.10.255
。默认网关通常为网络路由器。默认网关适用于不是以本地网络为目标的任何和所有流量,路由表中没有为其指定首选路由。
4.2. 使用 nmcli 配置静态路由
- nmcli 命令行
- nmcli 互动编辑器
例 4.1. 使用 nmcli 配置静态路由
~]# nmcli connection modify enp1s0 +ipv4.routes "192.168.122.0/24 10.10.10.1"
这会将 192.168.122.0/24
子网的流量定向到网关 10.10.10.1。
例 4.2. 使用 nmcli Editor 配置静态路由
~]$ nmcli con edit ens3 ===| nmcli interactive connection editor |=== Editing existing '802-3-ethernet' connection: 'ens3' Type 'help' or '?' for available commands. Type 'describe [<setting>.<prop>]' for detailed property description. You may edit the following settings: connection, 802-3-ethernet (ethernet), 802-1x, dcb, ipv4, ipv6, tc, proxy nmcli> set ipv4.routes 192.168.122.0/24 10.10.10.1 nmcli> save persistent Connection 'ens3' (23f8b65a-8f3d-41a0-a525-e3bc93be83b8) successfully updated. nmcli> quit
4.3. 使用 GUI 配置静态路由
- Routes
IP 地址
。IP 地址的子网掩码或前缀长度
。IP 地址
。- 当 Automatic 为 ON 时,会使用来自
RA
或DHCP
的路由,但您也可以添加其他静态路由。OFF 时,只使用您定义的静态路由。 - 仅将此连接用于其网络上的资源
- 选择这个复选框以防止连接成为默认路由。典型的示例是连接是 VPN 隧道或向头办公室的租期线,并且您不希望任何互联网入站流量通过连接。选择这个选项意味着只有专门用于路由的流量才会通过连接自动获得,或者手动输入到连接上。
4.4. 使用 ip 命令配置静态路由
IP
路由表,请使用 ip route 命令。例如:
~]$ ip route default via 192.168.122.1 dev ens9 proto static metric 1024 192.168.122.0/24 dev ens9 proto kernel scope link src 192.168.122.107 192.168.122.0/24 dev enp1s0 proto kernel scope link src 192.168.122.126
ip route [ add | del | change | append | replace ] destination-address
有关选项和格式的详情,请查看 ip-route(8)man
page。
~]# ip route add 192.0.2.1 via 10.0.0.1 [dev
interface]
IP 地址 ,100.0.1
是下一个跃点地址和 interface 是导致下一跃点的退出接口。
IP 地址的
IP 地址中
:
~]# ip route add 192.0.2.0/24 via 10.0.0.1 [dev
interface]
其中 192.0.2.0 是目标网络的 IP 地址 (点十进制表示法),/24
是网络前缀。网络前缀是子网掩码中已启用的位数。这种网络地址斜杠网络前缀长度的格式有时称为无类别域间路由 (CIDR)表示法。
~]# ip route del 192.0.2.1
/etc/sysconfig/network-scripts/
目录中为接口创建路由接口文件来配置这些路由
。例如,enp1s0 接口的静态路由将存储在 /etc/sysconfig/network-scripts/route-enp1s0
文件中。在重启网络服务或接口前,您对路由接口文件进行的任何更改都不会生效
。route-接口文件有两种格式
:
- IP 命令参数,请参阅 “使用 IP 命令参数格式的静态路由”一节。和
- 网络/子网掩码指令,请参见 “使用网络/网络掩码指令格式的静态路由”一节。
ip route 命令的详情,请查看 ip-route (8)
man page。
4.5. 在 ifcfg 文件中配置静态路由
/etc/sysconfig/network-scripts/
目录中的每个接口配置文件中。文件名应当为 route-接口的格式
。配置文件中有两种命令类型:
使用 IP 命令参数格式的静态路由
/etc/sysconfig/network-scripts/route-enp1s0)
,请在第一行中定义指向默认网关的路由。只有在没有通过 DHCP
设置网关且没有在 /etc/sysconfig/network
文件中全局设置时才需要此项:
default via 192.168.1.1 dev
interface
IP 地址
。接口是连接到或可以访问默认网关的接口。dev
选项可以省略,它是可选的。请注意,此设置优先于 /etc/sysconfig/network
文件中的设置。
10.10.10.0/24 via 192.168.1.1 [dev
interface]
IP 地址
。最好使用下一个跃点地址,但退出接口的地址可以正常工作。“下一跃点表示链路的远程末尾”,如网关或路由器。dev
选项可用于指定退出接口接口,但这不是必需的。根据需要添加任意数量的静态路由。
命令参数格式的路由接口文件示例
。默认网关为 192.168.0.1
,接口 enp1s0 以及租用的行或 WAN 连接位于 192.168.0.10
。这两个静态路由到达 10.10.10.0/24
网络和 172.16.1.10/32
主机:
default via 192.168.0.1 dev enp1s0 10.10.10.0/24 via 192.168.0.10 dev enp1s0 172.16.1.10/32 via 192.168.0.10 dev enp1s0
192.168.0.0/24 网络的数据包将被定向出连接到该网络的接口
。进入 10.10.10.0/24
网络和 172.16.1.10/32
主机的数据包将被定向到 192.168.0.10
。至未知的远程网络将使用默认网关,因此只有在默认路由不合适时,才应为远程网络或主机配置静态路由。此上下文中的 remote 表示没有直接连接到系统的任何网络或主机。
IPv6
配置,ip route 格式的 route6-接口
文件示例 :
2001:db8:1::/48 via 2001:db8::1 metric 2048 2001:db8:2::/48
ip route
格式可用于指定源地址。例如:
10.10.10.0/24 via 192.168.0.10 src 192.168.0.2
DHCP
已分配了默认网关,并且配置文件中指定了具有相同指标的同一网关,启动过程中或启动接口时会出现错误。可能会显示以下错误消息:"RTNETLINK 答案:"文件存在"。此错误可能会被忽略。
使用网络/网络掩码指令格式的静态路由
您还可以对路由接口文件使用
network/netmask 指令格式。以下是网络/子网掩码格式的模板,之后提供说明:
ADDRESS0=10.10.10.0 NETMASK0=255.255.255.0 GATEWAY0=192.168.1.1
ADDRESS0=10.10.10.0
是要访问的远程网络或主机的网络地址。NETMASK0=255.255.255.0
是使用ADDRESS0=10.10.10.0
定义的网络地址的子网掩码。GATEWAY0=192.168.1.1
是默认网关,或者可用于访问的IP 地址
ADDRESS0=10.10.10.0
指令格式的路由接口文件示例
。默认网关为 192.168.0.1
,但可通过 192.168.0.10
获得租用的行或 WAN 连接。这两个静态路由到达 10.10.10.0/24
和 172.16.1.0/24
网络:
ADDRESS0=10.10.10.0 NETMASK0=255.255.255.0 GATEWAY0=192.168.0.10 ADDRESS1=172.16.1.10 NETMASK1=255.255.255.0 GATEWAY1=192.168.0.10
ADDRESS0
、ADDRESS1
、ADDRESS2
等。
4.5.1. 了解策略路由
策略路由
也称为源路由,是一种更灵活的路由配置机制。路由决策通常根据软件包的目标 IP 地址做出。策略路由
可根据其他路由属性(如源 IP 地址、源端口和协议类型)提供更多灵活性来选择路由。路由表存储关于网络的路由表信息。它们通过数值或名称标识,可在 /etc/iproute2/rt_tables
文件中配置。默认表使用 254
来标识。使用 策略路由时
,您还需要规则。规则用于根据数据包的特定属性选择路由表。
ip route
格式可以用来定义基于策略的现有路由配置,该配置指定了多个路由表:
10.10.10.0/24 via 192.168.0.10 table 1 10.10.10.0/24 via 192.168.0.10 table 2
/etc/sysconfig/network-scripts/rule-enp1s0
文件,或编辑到 IPv4
的 /etc/sysconfig/network-scripts/rule6-enp1s0
文件。
ipv4.route-table
forIPv4
和ipv6.route-table
(适用于IPv6
)
DHCP
、autoconf6、DHCP6
的所有路由都
放置到该特定表中。此外,已配置地址的子网的所有路由都放置在相应的路由表中。例如,如果您配置 192.168.1.10/24 地址,则 192.168.1.0/24 子网包含在 ipv4.route-table 中。
policy-routing 规则
的详情,请查看 ip-rule(8)man
page。有关路由表,请查看 ip-route(8)man
page。
4.6. 配置默认网关
/etc/sysconfig/network
文件,然后由启动的接口的网络接口 ifcfg
文件 “确定”。ifcfg
文件按照数字顺序解析,最后一个要读取的 GATEWAY 指令则用于编写路由表中的默认路由。
/etc/sysconfig/network
文件已被弃用,现在应仅在每个接口配置文件中指定网关。
DHCP
分配。在需要影响网络管理器( NetworkManager )要用于访问网关的退出接口选择的特殊情况下,在 ifcfg
文件中为那些不导致默认网关的接口使用 DEFROUTE=no 命令。
第 5 章 配置网络连接设置
5.1. 配置 802.3 链接设置
802-3-ethernet.auto-negotiate
802-3-ethernet.speed
802-3-ethernet.duplex
- 忽略链路协商
- 强制自动协商激活
- 手动设置
速度和
双工
链接设置
忽略链路协商
802-3-ethernet.auto-negotiate = no 802-3-ethernet.speed = 0 802-3-ethernet.duplex = NULL
auto-negotiate
参数设置为 no
,但没有设置 速度和
双工
值,这并不表示禁用自动协商。
强制自动协商激活
802-3-ethernet.auto-negotiate = yes 802-3-ethernet.speed = 0 802-3-ethernet.duplex = NULL
手动设置链接速度和双工
手动配置
速度和双工
设置。
速度和
双工
链路设置,请按如下所示设置上述参数:
802-3-ethernet.auto-negotiate = no 802-3-ethernet.speed = [speed in Mbit/s] 802-3-ethernet.duplex = [half |full]
speed
和 duplex
值,否则 NetworkManager 不会更新链接配置。
- nmcli 工具
- nm-connection-editor 工具
使用 nmcli 工具配置 802.3 链接设置
流程
- 为 enp1s0 设备创建一个新的以太网连接。
- 将 802.3 链接设置设置为您选择的配置。详情请查看 第 5.1 节 “配置 802.3 链接设置”例如,手动将
速度选项 100
Mbit/s 和duplex
设置为 full :nmcli connection add con-name MyEthernet type ethernet ifname enp1s0 \ 802-3-ethernet.auto-negotiate no \ 802-3-ethernet.speed 100 \ 802-3-ethernet.duplex full
使用 nm-connection-editor 配置 802.3 链路设置
流程
- 在终端中输入 nm-connection-editor。
- 选择您要编辑的以太网连接,然后单击 gear wheel 图标以进入编辑对话框。如需更多信息,请参阅 第 3.4.3 节 “使用 nm-connection-editor 的通用配置选项”。
- 选择您选择的链接协商。
ignore
:跳过链接配置(默认)。Automatic
:在该设备中强制链接自动协商。Manual
:可以指定Speed
和Duplex
选项来强制实施链路协商。
图 5.1. 使用 nm-connection-editor 配置 802.3 链接设置
5.2. 配置 802.1X 安全性
过去,DHCP
服务器不配置为将 IP 地址租给未授权用户
,但出于各种原因,这种做法既不现实又不安全,因此不再推荐使用。取而代之,可使用 802.1X 安全性来确保通过基于端口的身份验证实现逻辑安全网络。
5.2.1. 使用 nmcli 为 Wi-Fi 配置 802.1X 安全性
流程
- 设置经过身份验证
的 key-mgmt
(密钥管理)协议。它为安全Wifi
连接配置密钥机制。有关属性的详情,请查看 nm-settings(5) man page。 - 配置 802-1x 身份验证设置。有关传输层安全性(TLS)身份验证,请参阅 “配置 TLS 设置”一节。
802-1X 身份验证设置 | 名称 | |
---|---|---|
802-1x.identity | 身份 | |
802-1x.ca-cert | CA 证书 | |
802-1x.client-cert | 用户证书 | |
802-1x.private-key | 私钥 | |
802-1x.private-key-password | 私钥密码 |
nmcli c add type wifi ifname wlo61s0 con-name 'My Wifi Network' \ 802-11-wireless.ssid 'My Wifi' \ 802-11-wireless-security.key-mgmt wpa-eap \ 802-1x.eap tls \ 802-1x.identity identity@example.com \ 802-1x.ca-cert /etc/pki/my-wifi/ca.crt \ 802-1x.client-cert /etc/pki/my-wifi/client.crt \ 802-1x.private-key /etc/pki/my-wifi/client.key \ 802-1x.private-key-password s3cr3t
5.2.2. 使用 nmcli 为 Wired 配置 802.1X 安全性
有线
连接,请遵循与 无线
连接相同的步骤,但 802-11-wireless.ssid
和 802-11-wireless-security.key-mgmt
设置除外。
5.2.3. 使用 GUI 为 Wi-Fi 配置 802.1X 安全性
流程
- 打开网络窗口 (请参阅 第 3.4.1 节 “使用 control-center GUI 连接到网络”)。
- 从右侧菜单中选择 Wireless 网络接口。如有必要,将符号链接电源按钮设置为 ON,并检查您的硬件交换机是否已开启。
- 选择新连接的连接名称,或者点击现有连接配置集的 gear wheel 图标,您要为其配置 802.1X 安全性。如果是新连接,请完成任何身份验证步骤来完成连接,然后单击 gear wheel 图标。
- 选择 Security。可用的配置选项如下:
- 安全性
- 密码
- 输入要在身份验证过程中使用的密码。
5.2.4. 使用 nm-connection-editor 为 Wired 配置 802.1X 安全性
流程
- 在终端中输入 nm-connection-editor。
~]$ nm-connection-editor
这时将显示Network Connections
窗口。 - 选择您要编辑的以太网连接并点击 gear wheel 图标,请参阅 第 3.4.6.2 节 “使用 nm-connection-editor 配置 Wired Connection”。
- 选择安全性并将符号链接电源按钮设置为 ON 以启用设置配置。
- 从以下验证方法中选择:
- 选择 TLS 用于传输层安全性,然后继续 “配置 TLS 设置”一节。
- 选择 FAST for Flexible Authentication via Secure Tunneling,再继续 “配置 Tunneled TLS 设置”一节;
- 为 Tunneled Transport Layer Security 选择 Tunneled TLS,否则称为 TTLS 或 EAP-TTLS,然后继续 “配置 Tunneled TLS 设置”一节 ;
- 选择 Protected EAP(PEAP) for Protected Extensible Authentication Protocol,再继续 “配置受保护的 EAP(PEAP)设置”一节。
配置 TLS 设置
- 身份
- 提供此服务器的身份。
- 用户证书
- 单击可浏览并选择个人 X.509 证书文件,这些证书文件编码为 Distinguished Encoding Rules (DER) 或隐私增强邮件(PEM )。
- CA 证书
- 单击可浏览并选择 X.509 证书颁发机构证书文件,这些证书颁发机构文件编码为 Distinguished Encoding Rules (DER)或 Privacy Enhanced Mail(PEM )。
- 私钥
- 点击以浏览并选择使用 Distinguished Encoding Rules (DER )、隐私增强邮件(PEM) 或个人信息交换语法标准 (PKCS #12) 编码的私钥文件。
- 私钥密码
- 在 Private key 字段中输入私钥的密码。选择 Show password 使密码在您键入时可见。
配置 FAST 设置
- 匿名身份
- 提供此服务器的身份。
- PAC 置备
- 选中要启用的复选框,然后从和 。
- PAC 文件
- 单击可浏览并选择受保护的访问凭据(PAC )文件。
- 内部身份验证
- username
- 输入要在身份验证过程中使用的用户名。
- 密码
- 输入要在身份验证过程中使用的密码。
配置 Tunneled TLS 设置
- 匿名身份
- 这个值被用作未加密的身份。
- CA 证书
- 单击浏览并选择证书认证机构的证书。
- 内部身份验证
- username
- 输入要在身份验证过程中使用的用户名。
- 密码
- 输入要在身份验证过程中使用的密码。
配置受保护的 EAP(PEAP)设置
- 匿名身份
- 这个值被用作未加密的身份。
- CA 证书
- 单击浏览并选择证书认证机构的证书。
- PEAP 版本
- 要使用的受保护 EAP 版本。自动、0 或 1.
- 内部身份验证
- username
- 输入要在身份验证过程中使用的用户名。
- 密码
- 输入要在身份验证过程中使用的密码。
5.3. 使用带有 wpa_supplicant 和 NetworkManager的 MACsec
介质访问控制安全
(MACsec
、IEEE 802.1AE)使用 GCM-AES-128 算法加密并验证 LAN 中的所有流量。MACsec
不仅可以保护 IP
,还可以保护地址解析协议(ARP)、邻居发现(ND)或 DHCP
。IPsec
在网络层(层 3)上运行,而 SSL 或
TLS
在应用层(层 7)上运行,而 MACsec
在数据链路层(层 2)中运行。将 MACsec
与其他网络层的安全协议相结合,以利用这些规则提供的不同安全功能。
MACsec
:
流程
- 创建 CAK/CKN 对。例如,以下命令在十六进制表示中生成 16 字节密钥:
~]$ dd if=/dev/urandom count=16 bs=1 2> /dev/null | hexdump -e '1/2 "%02x"'
- 创建
wpa_supplicant.conf
配置文件并添加以下行:ctrl_interface=/var/run/wpa_supplicant eapol_version=3 ap_scan=0 fast_reauth=1 network={ key_mgmt=NONE eapol_flags=0 macsec_policy=1 mka_cak=0011... # 16 bytes hexadecimal mka_ckn=2233... # 32 bytes hexadecimal }
使用上一步中的值完成wpa_supplicant.conf 配置文件中的ka_cak
和mka_ckn
行。如需更多信息,请参阅wpa_supplicant.conf(5)
man page。 - 假设您使用 wlp61s0 连接到您的网络,使用以下命令启动 wpa_supplicant :
~]# wpa_supplicant -i wlp61s0 -Dmacsec_linux -c wpa_supplicant.conf
wpa_supplicant.conf
文件,而不是创建和编辑 wpa_supplicant.conf 文件。以下示例假定您已有一个 16 字节十六进制 CAK($MKA_CAK
)和 32 字节十六进制 CKN($MKA_CKN
):
~]# nmcli connection add type macsec \ con-name test-macsec+ ifname macsec0 \ connection.autoconnect no \ macsec.parent wlp61s0 macsec.mode psk \ macsec.mka-cak $MKA_CAK \ macsec.mka-cak-flags 0 \ macsec.mka-ckn $MKA_CKN ~]# nmcli connection up test-macsec+
MACsec
网络架构、用例场景和配置示例的更多信息。
5.4. 配置 IPv4 设置
使用 control-center 配置 IPv4 设置
流程
- 按 Super 键进入 Activities Overview,键入 Settings,然后按 Enter 键。然后,选择左侧的网络
选项卡
,并显示 网络设置 工具。继续 “使用 control-center 配置新连接”一节。 - 选择您要编辑的连接并点击 gear wheel 图标。此时
将显示编辑
对话框。 - 单击 IPv4 菜单条目。
IP 地址
、DNS
和路由信息。当您创建和修改以下连接类型之一时,IPv4 菜单条目可用:有线、无线、移动宽带、VPN 或 DSL。
DHCP 从 DHCP
服务器获取动态 IP 地址 ,只需将地址设置为
)。
使用 nm-connection-editor 设置 IPV4 的方法
IPv4
设置:
流程
- 在终端中输入 nm-connection-editor。
- 对于现有连接类型,点击 gear wheel 图标。
图 5.2. 编辑连接
- 单击 IPv4 Settings。
图 5.3. 配置 IPv4 设置
按连接类型提供的可用 IPv4 方法
IPv4
连接方法之一:所有方法都根据与之关联的连接类型或类型在此处列出:
- wired、连线和 DSL 连接方法
DHCP
服务器分配IP 地址
,请选择这个选项。您无需填写 DHCP 客户端 ID 字段。DHCP
服务器分配IP 地址
,但您想要手动分配DNS
服务器,请选择这个选项。IP 地址
,请选择这个选项。10.42.x.1/24
范围、DHCP
服务器和DNS
服务器,并且接口连接到系统上具有网络地址转换 (NAT)的默认网络连接。IPv4
。- 移动带宽连接方法
IP
地址和DNS
服务器,请选择这个选项。IP 地址
,请选择这个选项,但您想要手动指定DNS
服务器。- VPN 连接方法
IP
地址和DNS
服务器,请选择这个选项。IP 地址
,请选择这个选项,但您想要手动指定DNS
服务器。- DSL 连接方法
IP
地址和DNS
服务器,请选择这个选项。IP 地址
,请选择这个选项,但您想要手动指定DNS
服务器。
DHCP 从 DHCP
服务器获取动态 IP 地址
,只需将 Method 设置为 )。
5.5. 配置 IPv6 设置
- 方法
IPv6
设置,请选择这个选项。DNS
服务器,请选择此选项。DHCPv6
请求信息以创建有状态配置。IP 地址
,请选择这个选项。- 地址
DNS
服务器列表。
5.6. 配置 PPP(点对点)设置
身份验证方法
- 使用点对点加密(MPPE)
- Microsoft Point-To-Point 加密协议(RFC 3078)。
- 允许 BSD 数据压缩
- PPP BSD 压缩协议(RFC 1977)。
- 允许取消数据压缩
- PPP 调试协议(RFC 1979)。
- 使用 TCP 标头压缩
- 低速串行链接(RFC 1144)压缩 TCP/IP 标头。
- 发送 PPP echo 数据包
- 用于回环测试的 LCP Echo-Request 和 Echo-ReplyCodes(RFC 1661)。
第 6 章 配置主机名
6.1. 了解主机名
主机名有三种类型
:静态、友好和瞬态。
主机名”,可由用户选择,存储在 /etc/hostname
文件中。“临时
主机名是由内核维护的动态主机名”。默认情况下,它将初始化为静态主机名,其值默认为 “localhost”。它可以在运行时由 DHCP
或 mDNS
更改。“用户友善
的主机名是一个自由格式” UTF8 主机名,供用户使用。
DNS
中用于完全限定域名(FQDN)匹配,如 host.example.com
。此外,建议静态和临时名称仅包含 7 位 ASCII 小写字符、没有空格或点,并将自身限制为 DNS
域名标签允许的格式,即使这不是严格的要求。旧规格不允许下划线,因此不建议使用它们。
a-z
、A-Z
、0-9、-
、_ “和
” “.
” 仅(不以“点
” 开始或结束),且不要紧接点后有两个点。强制实施 64 个字符的大小限制。
6.1.1. 推荐的命名实践
有时会在公共寄存器中添加以前未注册的顶级域(如.your
companyany)。因此,红帽强烈建议您不要使用没有委托给您的域名,即使使用私有网络中也是如此,因为这可能导致根据网络配置的不同解析域名。因此,网络资源可能会不可用。使用未委派的域名也会增加 DNSSEC 部署和维护的难度,因为域名冲突需要手动配置来启用 DNSSEC 验证。 有关此问题的更多信息,请参阅域名冲突上的 ICANN 常见问题解答。
6.2. 使用文本用户界面配置主机名,nmtui
~]$ nmtui
此时将显示文本用户界面。任何无效的命令都会打印用法消息。
图 6.1. NetworkManager 文本用户界面起始菜单
[D]
/etc/hostname
文件中的静态主机名。
systemd-hostnamed
服务读取和写入静态主机名,该主机名存储在 /etc/hostname
文件中。因此,NetworkManager 不再自动对 /etc/hostname
文件进行手动修改;您应该通过 hostnamectl 实用程序更改系统主机名。另外,在 /etc/sysconfig/network
文件中使用HOSTNAME
变量现已弃用。
6.3. 使用 hostnamectl 配置主机名
6.3.1. 查看所有主机名
~]$ hostnamectl status
如果未指定 选项,则默认表示 status
选项。
6.3.2. 设置所有主机名
root
用户身份输入以下命令:
~]# hostnamectl set-hostname name
这将改变好奇、静态和瞬态主机名等。静态和临时主机名将简化用户友善主机名的形式。空格将被替换为 “-
”,并且将删除特殊字符。
6.3.3. 设置部分主机名
root
用户身份输入以下命令并带有相关选项:
~]# hostnamectl set-hostname name [option...]
其中 选项是 --pretty
、--static 和 --
transient 的一个或多个
。
--static
或 --transient
选项与 --pretty
选项一同使用,静态和临时主机名将会简化用户友善主机名的形式。空格将被替换为 “-
”,并且将删除特殊字符。如果未提供 --pretty
选项,则不会进行简化。
~]# hostnamectl set-hostname "Stephen's notebook" --pretty
6.3.4. 清除具体主机名
root
用户身份使用相关选项输入以下命令:
~]# hostnamectl set-hostname "" [option...]
其中""是一个带引号的空字符串,其中 选项为一个或多个
:--pretty
、--static 和 --transient
。
6.3.5. 远程更改主机名
-H, --host
选项,如下所示:
~]# hostnamectl set-hostname -H
[username]@hostname
其中 hostname 是您要配置的远程主机。用户名是可选的。hostnamectl 工具将使用 SSH
连接到远程系统。
6.4. 使用 nmcli 配置主机名
/etc/hostname
文件中的静态主机名。
~]$ nmcli general hostname
要将静态主机名设置为 my-server,以 root
用户身份运行以下命令:
~]# nmcli general hostname my-server
6.5. 其它资源
hostnamectl(1)
man page - 描述 hostnamectl,包括命令和命令选项。hostname(1)
手册页 - 包含主机名和 域名命令的说明。hostname(5)
手册页 - 包含主机名文件及其内容和使用的说明.hostname(7)
man page - 包含主机名解析的说明。machine-info(5)
手册页 - 描述本地计算机信息文件及其包含的环境变量。machine-id(5)
手册页 - 描述本地机器 ID 配置文件。systemd-hostnamed.service(8)man
page - 描述 hostnamectl 使用的systemd-hostnamed
系统服务。
第 7 章 配置网络绑定
7.1. 了解控制器和端口接口的默认行为
NetworkManager
守护进程控制绑定端口接口时,特别是在查找故障时,请牢记以下几点:
- 启动控制器接口不会自动启动端口接口。
- 启动端口接口总会启动控制器接口。
- 停止控制器接口也会停止端口接口。
- 没有端口的控制器可以启动静态
IP
连接。 - 没有端口的控制器在启动
DHCP
连接时会等待端口。 - 当添加具有载波的端口时,等待端口且具有
DHCP
连接的控制器会完成。 - 当添加不具有载体的端口时,等待端口且具有
DHCP
连接的控制器将继续等待。
7.2. 使用文本用户界面 nmtui 配置绑定
~]$ nmtui
此时将显示文本用户界面。任何无效的命令都会打印用法消息。
- 在起始菜单中选择 Edit a connection。选择 Add,这会打开 New Connection 屏幕。
图 7.1. NetworkManager 文本用户界面添加绑定连接菜单
[D] - 选择 Bond,然后选择 Create ;绑定的编辑连接屏幕将打开。
图 7.2. NetworkManager 文本用户界面配置 Bond Connection 菜单
[D] - 此时,需要将端口接口添加到绑定中;要添加这些选择添加添加 添加,可打开 New Connection 屏幕。选择连接类型后,选择创建按钮。
图 7.3. NetworkManager 文本用户界面配置新绑定从连接菜单
[D] - 端口的 Edit Connection 显示会出现 ; 在 Device 部分输入所需端口的设备名称或 MAC 地址。如果需要,通过选择 Show to the Ethernet 标签右侧输入要用作绑定 MAC 地址的克隆 MAC 地址。选择 OK 按钮以保存端口。注意如果设备没有 MAC 地址指定,则当 Edit Connection 窗口重新加载后,仅当成功找到该设备时,会自动填充 Device 部分。
图 7.4. NetworkManager 文本用户界面配置 Bond Slave Connection 菜单
[D] - 绑定端口的名称会出现在 Slaves 部分。重复上述步骤,以添加其他端口连接。
- 在选择确定按钮之前,检查并确认设置。
图 7.5. NetworkManager 文本用户界面完成绑定
[D]
7.3. 使用 NetworkManager 命令行工具 nmcli 进行网络绑定
绑定
连接,请运行以下命令:
~]$ nmcli con add type bond ifname mybond0
Connection 'bond-mybond0' (5f739690-47e8-444b-9620-1895316a28ba) successfully added.
con-name
,因此连接名称是通过在类型前前从接口名称衍生而来的。
~]$ nmcli con add type bond ifname mybond0 bond.options "mode=balance-rr,miimon=100"
Connection 'bond-mybond0' (5f739690-47e8-444b-9620-1895316a28ba) successfully added.
- 创建新连接,详情请参阅 第 3.3.5 节 “使用 nmcli 创建和修改连接配置集”。
- 将 controller 属性设置为
绑定接口
名称,或设置为控制器连接的名称:
~]$ nmcli con add type ethernet ifname ens3 master mybond0
Connection 'bond-slave-ens3' (220f99c6-ee0a-42a1-820e-454cbabc2618) successfully added.
例如:
~]$ nmcli con add type ethernet ifname ens7 master mybond0
Connection 'bond-slave-ens7' (ecc24c75-1c89-401f-90c8-9706531e0231) successfully added.
~]$ nmcli con up bond-slave-ens7
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/14)
~]$ nmcli con up bond-slave-ens3
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/15)
active_slave
选项和绑定的主选项
,而不激活连接。例如要更改 active_slave
选项,请使用以下命令:
~]$ nmcli dev mod bond0 +bond.options "active_slave=ens7"
Connection successfully reapplied to device 'bond0'.
或者更改主选项
:
~]$ nmcli dev mod bond0 +bond.options "primary=ens3"
Connection successfully reapplied to device 'bond0'.
active_slave
选项设定当前活动端口,而绑定 的主
选项指定了在添加新端口或发生活跃端口时,内核会自动选择的活动端口。
7.4. 使用命令行界面(CLI)
bonding
内核模块和名为通道绑定接口的特殊网络接口创建绑定。
7.4.1. 检查 Bonding 内核模块是否已安装
root
用户身份运行以下命令来载入该模块:
~]# modprobe --first-time bonding
此激活在系统重启后不会保留。有关永久模块加载的解释,请参阅Red Hat Enterprise Linux 内核管理指南。请注意,如果配置文件使用了 BONDING_OPTS 指令,则 bonding 模块将根据需要加载,因此不需要单独加载。
~]$ modinfo bonding
有关更多命令选项,请参阅 modprobe(8)手册页
。
7.4.2. 创建频道绑定接口
/etc/sysconfig/network-scripts/
目录中创建一个名为 ifcfg-bondN
的文件,将 N 替换为接口的数字,如 0
。
DEVICE
指令是 bondN,将 N
替换为接口的编号,而 TYPE=Bond 则替换为 TYPE=Bond。此外,设置 BONDING_MASTER=yes。
例 7.1. ifcfg-bond0 接口配置文件示例
DEVICE=bond0 NAME=bond0 TYPE=Bond BONDING_MASTER=yes IPADDR=192.168.1.1 PREFIX=24 ONBOOT=yes BOOTPROTO=none BONDING_OPTS="bonding parameters separated by spaces" NM_CONTROLLED="no"
BONDING_OPTS="bonding parameters"
指令(在 ifcfg-bondN
接口文件中)中的空格分隔列表。不要在 /etc/modprobe.d/bonding.conf
中或已弃用的 /etc/modprobe.conf
文件中指定绑定设备的选项。
max_bonds
参数不特定于接口,在使用带有 BONDING_OPTS 指令的 ifcfg-bondN
文件时,不应设置,因为此指令将导致网络脚本根据需要创建绑定接口。
7.4.3. 创建端口接口
主
),要绑定的接口被称为端口(从)。
创建通道绑定接口后,必须通过在端口的配置文件中添加 MASTER
和 SLAVE
指令来配置要绑定的网络接口。每个端口接口的配置文件几乎相同。
例 7.2. 端口接口配置文件示例
enp1s0
和 enp2s0
,它们可以类似以下示例:
DEVICE=device_name NAME=bond0-slave TYPE=Ethernet BOOTPROTO=none ONBOOT=yes MASTER=bond0 SLAVE=yes NM_CONTROLLED="no"
7.4.4. 激活频道绑定
root
身份运行以下命令:
~]# ifup ifcfg-enp1s0
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/7)
~]# ifup ifcfg-enp2s0
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/8)
ifdown device_name在完成后,打开所有端口,这将打开绑定(如果尚未设置)。“” “”
root 用户身份为每个更改的接口发出命令
:
~]# nmcli con load /etc/sysconfig/network-scripts/ifcfg-device
另外,重新载入所有接口:
~]# nmcli con reload
默认行为是网络管理器(NetworkManager )不知晓这些更改并继续使用旧配置数据。这由 NetworkManager.conf
文件中的 monitor-connection-files
选项设置。如需更多信息,请参阅 NetworkManager.conf(5)
手册页。
~]# ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: enp1s0: <BROADCAST,MULTICAST,SLAVE,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master bond0 state UP mode DEFAULT qlen 1000
link/ether 52:54:00:e9:ce:d2 brd ff:ff:ff:ff:ff:ff
3: enp2s0: <BROADCAST,MULTICAST,SLAVE,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master bond0 state UP mode DEFAULT qlen 1000
link/ether 52:54:00:38:a6:4c brd ff:ff:ff:ff:ff:ff
4: bond0: <BROADCAST,MULTICAST,MASTER,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT
link/ether 52:54:00:38:a6:4c brd ff:ff:ff:ff:ff:ff
7.4.5. 创建多个绑定
- 使用 BONDING_OPTS 指令创建多个
ifcfg-bondN
文件;此指令将导致网络脚本根据需要创建绑定接口。 - 创建或编辑要绑定的现有接口配置文件,并包含 SLAVE 指令。
- 通过 MASTER 指令,将接口绑定到通道绑定接口。
例 7.3. ifcfg-bondN 接口配置文件示例
DEVICE=bondN NAME=bondN TYPE=Bond BONDING_MASTER=yes IPADDR=192.168.1.1 PREFIX=24 ONBOOT=yes BOOTPROTO=none BONDING_OPTS="bonding parameters separated by spaces"
ifcfg-bond0
和 ifcfg-bond1
(具有适当的 IP 地址
):
7.5. 验证冗余的网络配置绑定
流程
- 从绑定接口 Ping 目标 IP。例如:
~]# ping -I bond0 DSTADDR
- 查看处于
活跃
模式的接口:~]# cat /sys/class/net/bond0/bonding/active_slave enp1s0
enp1s0 是活动
端口接口。 - 设置
活跃
端口接口缩减:~]# ip link set enp1s0 down
- 检查
备份
接口是否已启动:~]# cat /sys/class/net/bond0/bonding/active_slave enp2s0
enp2s0 现在是活动的
端口接口。 - 检查您是否仍然可以从绑定接口 ping 目标 IP:
~]# ping -I bond0 DSTADDR
7.6. 切换中绑定模式和所需设置概述
绑定模式 | Switch 上的配置 |
---|---|
0 - balance-rr | 需要启用静态的 Etherchannel(未启用 LACP 协商) |
1 - active-backup | 需要可自主端口 |
2 - balance-xor | 需要启用静态的 Etherchannel(未启用 LACP 协商) |
3 - broadcast | 需要启用静态的 Etherchannel(未启用 LACP 协商) |
4 - 802.3ad | 需要启用 LACP 协商的 Etherchannel |
5 - balance-tlb | 需要可自主端口 |
6 - balance-alb | 需要可自主端口 |
7.7. 使用频道绑定
7.7.1. 绑定模块指令
BONDING_OPTS=" 绑定参数" 指令(例如ifcfg-bond0)之前,最好测试哪个通道绑定模块参数
最适合您的绑定接口参数
。通过处理 sysfs
文件系统中的文件,可以在不卸载(和重新加载)绑定模块的情况下配置绑定接口的参数。
sysfs
是将内核对象表示为目录、文件和符号链接的虚拟文件系统。sysfs
可用于查询有关内核对象的信息,也可通过使用普通文件系统命令来操控这些对象。sysfs
虚拟文件系统挂载到 /sys/
目录下。通过与 /sys/class/net/
目录交互和管理文件,可以动态配置所有绑定接口。
ifcfg-bond0。
在绑定到 bond 0 的每个接口的配置文件中插入 SLAVE=yes
和 MASTER=bond
0
指令。完成此操作后,您可以继续测试参数。
root
用户身份运行 ifup bondN
来打开您创建的绑定:
~]# ifup bond0
ifcfg-bond0
bonding 接口文件,您可以看到运行 ip 链接的输出中列出的 bond0
以 root
用户身份显示 :
~]# ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: enp1s0: <BROADCAST,MULTICAST,SLAVE,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master bond0 state UP mode DEFAULT qlen 1000
link/ether 52:54:00:e9:ce:d2 brd ff:ff:ff:ff:ff:ff
3: enp2s0: <BROADCAST,MULTICAST,SLAVE,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master bond0 state UP mode DEFAULT qlen 1000
link/ether 52:54:00:38:a6:4c brd ff:ff:ff:ff:ff:ff
4: bond0: <BROADCAST,MULTICAST,MASTER,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT
link/ether 52:54:00:38:a6:4c brd ff:ff:ff:ff:ff:ff
~]$ cat /sys/class/net/bonding_masters
bond0
/sys/class/net/bondN/bonding/
目录中的文件来单独配置每个绑定。首先,您要配置的绑定必须关闭:
~]# ifdown bond0
root
用户身份运行:
~]# echo 1000 > /sys/class/net/bond0/bonding/miimon
balance-alb
模式配置 bond0,请运行:
~]# echo 6 > /sys/class/net/bond0/bonding/mode
~]# echo balance-alb > /sys/class/net/bond0/bonding/mode
sysfs
修改其参数,将其备份并重新测试。
/etc/sysconfig/network-scripts/ifcfg-bondN
文件的 BONDING_OPTS=
指令中。每当该绑定被启动(例如,当设置了 ONBOOT=yes
指令时,系统在引导序列中,在 BONDING_OPTS
中指定的绑定选项将会对那个绑定生效)。
parm
的简短描述,或者参阅 https://www.kernel.org/doc/Documentation/networking/bonding.txt。
绑定接口参数
-
ad_select=value
- 指定要使用的 802.3ad 聚合选择逻辑。可能的值有:
stable
或者0
- 默认设置。活动聚合器由最大的聚合带宽来选择。只有在活跃聚合器的所有端口都停机或活跃聚合器没有端口时,才会重新选择活跃的聚合器。bandwidth
或者1
- 活跃的聚合器由最大聚合带宽选择。在以下情况下进行重新选择:- 在绑定中添加或删除了端口 ;
- 任何端口的链接状态更改;
- 任何端口的 802.3ad 关联状态更改;
- 绑定的管理状态变为 up。
count
或者2
- 活跃的聚合器由最大端口数量选择。重新选择按照上述带宽设置所述进行
。
当活跃聚合器发生部分故障时,带宽和
802.3ad 聚合。这会使聚合器具有最高的可用性,可以是带宽或端口数量,随时激活。计数选择策略允许故障转移
-
arp_interval=time_in_milliseconds
- 以毫秒为单位指定
ARP 监控的频率
。重要务必要同时指定arp_interval
和arp_ip_target
参数,或者指定miimon
参数。否则可能会导致链接失败时的网络性能下降。如果在 mode=0 或 mode
=2(
两种负载平衡模式)中使用这个设置,网络交换机必须配置为在 NIC 间平均分发数据包。有关如何完成此操作的详情请参考 https://www.kernel.org/doc/Documentation/networking/bonding.txt。该值默认设置为0
,它会禁用它。 -
arp_ip_target=ip_address[,ip_address_2,…ip_address_16]
- 在启用
arp_interval
参数时,指定ARP 请求
的目标IP 地址
。最多可在逗号分隔列表中指定最多 16 个IP 地址
。 -
arp_validate=value
- 验证
ARP
探测的来源/分发;默认为none
。其他有效值包括active
、backup
和all
。 -
downdelay=time_in_milliseconds
- 指定在禁用链接失败前需要等待多久(以毫秒为单位)。该值必须是
miimon
参数中指定的值的倍数。该值默认设置为0
,它会禁用它。 -
fail_over_mac=value
- 指定 active-backup 模式是否应该在分配时(传统行为)点把所有端口设置为相同的 MAC 地址(启用时),或者根据所选策略执行绑定 MAC 地址的特殊处理。可能的值有:
none
或者0
- 默认设置。此设置禁用fail_over_mac
,并使绑定在分配时将 active-backup 绑定的所有端口设置为同一 MAC 地址。active
或者1
- “活跃的”fail_over_mac
策略表示绑定的 MAC 地址应该始终是当前活跃端口的 MAC 地址。端口的 MAC 地址没有改变,而是在故障切换过程中更改绑定的 MAC 地址。此策略对无法更改 MAC 地址的设备或拒绝传入广播的设备和自己的源 MAC(会干扰 ARP 监控器)的设备很有用。此策略的缺点在于,网络中的每个设备都必须通过粒度 ARP 更新,而非检测传入流量以更新其 ARP 表的正常交换机方法。如果发行版 ARP 丢失,通信可能会中断。当此策略与 MII 监控器结合使用时,在实际传输和接收之前确认链接的设备特别容易遭受无饱和性 ARP 的损失,并且可能需要适当的延迟设置。follow
或者2
- 以下fail_over_mac
策略会导致正常选择绑定的 MAC 地址(通常是添加到绑定的第一个端口的 MAC 地址)。“”但是,第二个和后续端口没有在备份角色中被设置为这个 MAC 地址;一个端口在故障转移时被编程为带有绑定的 MAC 地址(而前者活跃端口接收新活跃端口的 MAC 地址)。此策略对多端口设备很有用,当多个端口被编程为相同的 MAC 地址时,这些设备会变得混乱或造成性能损失。
- lacp_rate=value
- 指定链接合作伙伴应在 802.3ad 模式下传输 LACPDU 数据包的速率。可能的值有:
slow
或者0
- 默认设置。这规定合作伙伴应每 30 秒传输一次 LACPDU。fast
或1
- 指定合作伙伴应每 1 秒传输一次 LACPDU。
-
miimon=time_in_milliseconds
- 指定 MII 链接监控的频率(以毫秒为单位)。如果需要高可用性,这很有用,因为 MII 用于验证 NIC 是否活跃。要验证特定 NIC 的驱动程序是否支持 MII 工具,以 root 用户身份输入以下命令:
~]# ethtool interface_name | grep "Link detected:"
在这个命令中,将 interface_name 替换为设备接口的名称,如enp1s0
,而不是绑定接口。如果支持 MII,命令会返回:Link detected: yes
如果使用绑定接口来实现高可用性,则每个 NIC 的模块必须支持 MII。将值设置为0
(默认值),关闭此功能。在配置此设置时,此参数的良好起点是100
。重要务必要同时指定arp_interval
和arp_ip_target
参数,或者指定miimon
参数。否则可能会导致链接失败时的网络性能下降。 -
mode=值
- 允许您指定绑定策略。该值可以是 :
balance-rr
或0
- 为容错和负载均衡设置循环策略。每个绑定接口中按顺序接收和发送传输时,从第一个可用端口接口开始。active-backup
或1
- 为容错设置主动备份策略。通过第一个可用的绑定接口接收和发送传输。只有在活跃的绑定端口接口失败时,才会使用另一个绑定的端口接口。balance-xor
或者2
- 传输基于所选的 hash 策略。默认值为根据源的 XOR 和目的地 MAC 地址生成哈希值,以端口接口的模数乘以模数。在此模式中,目标为特定同级的通信始终将通过同一个接口发送。由于目的地由 MAC 地址决定,此方法最适合发送到同一链路或本地网络上同级设备的通信。如果流量必须穿过单个路由器,这种流量均衡模式将不理想。broadcast
或3
- 为容错设置广播策略。所有传输都将在所有端口接口上发送。802.3ad
或4
- 设置 IEEE 802.3ad 动态链路聚合策略。创建共享相同速度和双工设置的聚合组。在活跃的聚合器中的所有端口上传输并接收接收。需要兼容 802.3ad 的交换机。balance-tlb
或5
- 为容错和负载均衡设置传输负载平衡(TLB)策略。传出流量会根据每个端口接口的当前负载进行分发。传入流量由当前端口接收。如果接收端口失败,则另一个端口通过失败的端口的 MAC 地址。此模式仅适用于内核绑定模块已知的本地地址,因此无法与虚拟机在桥接后面使用。balance-alb
或者6
- 为容错和负载均衡设置自适应负载均衡(ALB)策略。包括IPv4
流量的传输和接收负载平衡。通过ARP
协商实现负载平衡。此模式仅适用于内核绑定模块已知的本地地址,因此无法与虚拟机在桥接后面使用。
有关上游交换机上所需设置的详情,请参考 第 7.6 节 “切换中绑定模式和所需设置概述”。 -
primary=interface_name
- 指定主设备的接口名称,如
enp1s0
。主
设备是要使用的绑定接口中的第一个,除非失败,否则不会被恢复。当绑定接口中的一个 NIC 速度更快,因此能够处理更大的负载时,此设置特别有用。这个设置只有在绑定接口处于active-backup
模式时才有效。如需更多信息,请参阅 https://www.kernel.org/doc/Documentation/networking/bonding.txthttps://www.kernel.org/doc/Documentation/networking/bonding.txt。 -
primary_reselect=value
- 指定主端口的 reselection 策略。这会影响选择在主端口故障或恢复主端口时如何成为活动端口的激活端口。这个参数用于防止在主端口和其他端口之间进行软盘。可能的值有:
always
或者0
(默认)- 主端口在备份时都会变为活跃端口。better
或者1
- 当主端口恢复时,主端口成为活跃端口,如果主端口的速度和双工比当前活跃端口的速度和 duplex 更好。failure
或者2
- 只有当前活跃端口失败且主端口启动时才会激活端口。
在两种情况下,primary_reselect
设置会被忽略:- 如果没有激活端口,则要恢复的第一个端口就会变为活动端口。
- 最初分配给绑定时,主端口始终由活动端口组成。
通过sysfs
更改 main_reselect
策略将导致根据新策略立即选择最佳活跃端口。根据具体情况,这可能会造成活动端口的更改 -
resend_igmp=range
- 指定要在故障转移事件后发布的 IGMP 成员资格报告的数量。故障转移后会立即发布一份成员报告,后续数据包每 200ms 间隔发送一次。有效范围为
0
到255
;默认值为1
。值为0
可防止为响应故障转移事件发布 IGMP 成员资格报告。这个选项对于绑定模式 balance-rr (模式 0)、active-backup (模式 1)、balance-tlb (模式 5)和 balance-alb (模式 6)来说非常有用,其中的故障转移可将 IGMP 流量从一个端口切换到另一个端口。因此,必须发布全新的 IGMP 报告以使交换机通过新选定的端口转发传入的 IGMP 流量。 -
updelay=time_in_milliseconds
- 指定(以毫秒为单位)在启用链接前等待多长时间。该值必须是
miimon
参数中指定的值的倍数。该值默认设置为0
,它会禁用它。 -
use_carrier=number
- 指定
miimon
是否应该使用 MII/ETHTOOL ioctls 或netif_carrier_ok()
来确定链接状态。netif_carrier_ok()
功能依赖于设备驱动程序使用netif_carrier_on/off
维护其状态;大多数设备驱动程序都支持这个功能。MII/ETHTOOL ioctls 工具使用内核中已弃用的调用序列。但是,如果您的设备驱动程序不支持netif_carrier_on/off
,这仍然可以被配置。有效值为:1
- 默认设置.启用使用netif_carrier_ok()
。0
- 启用使用 MII/ETHTOOL ioctls。
注意如果绑定接口坚持链接不应启动,则您的网络设备驱动程序可能不支持netif_carrier_on/off
。 -
xmit_hash_policy=value
- 选择在
balance-xor
和802.3ad
模式中用于端口选择的传输哈希策略。可能的值有:0
或者layer2
- 默认设置。此参数使用硬件 MAC 地址的 XOR 来生成哈希。使用的公式是:(source_MAC_address XOR destination_MAC) MODULO slave_count
此算法会将所有流量都放在同一端口上的特定网络对等点上,兼容 802.3ad。1
或者layer3+4
- 使用上层协议信息(可用时)生成哈希。这允许到特定网络对等的流量跨越多个端口,但单一连接不跨越多个端口。使用的 TCP 和 UDP 数据包的公式为:((source_port XOR dest_port) XOR ((source_IP XOR dest_IP) AND
0xffff
) MODULO slave_count对于碎片 TCP 或 UDP 数据包以及所有其他IP
协议流量,将省略源和目标端口信息。对于非IP
流量,公式与 L2 传输哈希策略相同。该政策旨在模拟某些交换机的行为;特别是,Cisco 使用 PFC2 以及一些 Foundry 和 IBM 产品进行切换。此策略使用的算法不兼容 802.3ad。2
或layer2+3
- 使用 layer2 和 layer3 协议信息的组合来生成哈希。使用硬件 MAC 地址和IP 地址
XOR 生成哈希。公式是:(((source_IP XOR dest_IP) AND
0xffff
) XOR ( source_MAC XOR destination_MAC )) MODULO slave_count此算法会将所有流量都放在同一端口上的特定网络对等点。对于非IP
流量,公式与 L2 传输哈希策略相同。此策略旨在提供比 L2 更均衡的流量分布,特别是在需要 L3 网关设备到达大多数目的地的环境中。这个算法符合 802.3ad。
7.8. 使用 GUI 创建绑定连接
7.8.1. 建立绑定连接
过程 7.1. 添加新 Bond Connection_Using nm-connection-editor
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 单击添加按钮。此时将显示 Choose a Connection Type 窗口。选择 Bond,再单击 Create。此时将显示 Editing Bond connection 1 窗口。
图 7.6. NetworkManager 图形用户界面添加 Bond 菜单
[D] - 在 Bond 选项卡中,点 并选择您要用于绑定连接的接口类型。 。请注意,仅当您创建第一个端口时才会出现选择端口类型的对话框;之后,它将自动将同一类型用于所有后续端口。
- 此时将显示编辑 bond0 从属 1 窗口。使用设备 MAC 地址下拉菜单选择要绑定的接口的 MAC 地址。第一个端口的 MAC 地址将用作绑定接口的 MAC 地址。如果需要,输入要用作绑定 MAC 地址的克隆 MAC 地址。 。
图 7.7. NetworkManager 图形用户界面添加 Bond 连接菜单
[D] - 绑定端口的名称会出现在绑定连接 窗口中。 。
- 检查并确认设置,然后单击保存按钮。
- 请参考以下 第 7.8.1.1 节 “配置 Bond 选项卡” 来编辑特定于绑定的设置。
过程 7.2. 编辑现有的 Bond 连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 选择您要编辑的连接并点击 Edit 按钮。
- 选择常规选项卡。
- 配置连接名称、自动连接行为和可用性设置。Editing 对话框中的五个设置对所有连接类型通用,请参阅 General 选项卡:
- 连接名称 - 输入您的网络连接描述性名称。此名称将用于在 Network 窗口的菜单中列出此连接。
- 当这个网络可用时自动连接到这个网络 - 如果您希望 NetworkManager 在可用时自动连接到这个连接,请选择这个框。如需更多信息,请参阅 “使用 control-center 编辑现有连接”一节。
- 所有用户可以连接到此网络 - 选择此框可创建系统上所有用户可用的连接。更改此设置可能需要 root 特权。详情请查看 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
- 使用这个连接时自动连接到 VPN - 如果您希望 NetworkManager 在有可用时自动连接到 VPN 连接,请选择这个框。从下拉菜单中选择 VPN。
- firewall Zone - 从下拉菜单中选择防火墙区域。有关防火墙区域的更多信息,请参阅Red Hat Enterprise Linux 7 安全指南。
- 请参考以下 第 7.8.1.1 节 “配置 Bond 选项卡” 来编辑特定于绑定的设置。
保存您的新(或修改)连接并创建进一步配置
- 或者
7.8.1.1. 配置 Bond 选项卡
- 模式
- 用来通过组成绑定的端口连接共享流量的模式。默认值为 round-robin。可以通过下拉列表来选择其他负载共享模式,如
802.3ad
。 - 链接监控
- 监控端口可以传输网络流量的方法。
- round-robin
- 为容错和负载平衡设置循环策略。每个绑定接口中按顺序接收和发送传输时,从第一个可用端口接口开始。如果没有额外的交换机配置,此模式可能无法与虚拟机桥接之后工作。
- 活跃备份
- 设置用于容错的 active-backup 策略。通过第一个可用的绑定接口接收和发送传输。只有在活跃的绑定端口接口失败时,才会使用另一个绑定的端口接口。请注意,这是 InfiniBand 设备绑定的唯一模式。
- XOR
- 设置 XOR(独占-或)策略。传输基于所选哈希策略。默认值为根据源的 XOR 和目的地 MAC 地址生成哈希值,以端口接口的模数乘以模数。在此模式中,目标为特定同级的通信始终将通过同一个接口发送。由于目的地由 MAC 地址决定,此方法最适合发送到同一链路或本地网络上同级设备的通信。如果流量必须穿过单个路由器,这种流量均衡模式将不理想。
- broadcast
- 为容错设置广播策略。所有传输都将在所有端口接口上发送。如果没有额外的交换机配置,此模式可能无法与虚拟机桥接之后工作。
- 802.3ad
- 设置 IEEE
802.3ad
动态链路聚合策略。创建共享相同速度和双工设置的聚合组。在活跃的聚合器中的所有端口上传输并接收接收。需要兼容802.3ad
的网络交换机。 - 自适应传输负载平衡
- 设置用于容错和负载平衡的自适应传输负载平衡(TLB)策略。传出流量会根据每个端口接口的当前负载进行分发。传入流量由当前端口接收。如果接收端口失败,则另一个端口通过失败的端口的 MAC 地址。此模式仅适用于内核绑定模块已知的本地地址,因此无法与虚拟机在桥接后面使用。
- 自适应负载平衡
- 设置用于容错和负载平衡的自适应负载平衡(ALB)策略。包括
IPv4
流量的传输和接收负载平衡。通过ARP
协商实现负载平衡。此模式仅适用于内核绑定模块已知的本地地址,因此无法与虚拟机在桥接后面使用。
- MII(媒体独立接口)
- 接口的载波状态受到监控。这可以通过查询驱动程序、直接查询 MII 寄存器或使用 ethtool 查询设备来完成。有三个可用的选项:
- 监控频率
- 查询驱动程序或 MII 寄存器之间的时间间隔,以毫秒为单位。
- 链接延迟
- 尝试使用报告为 up 的链接(以毫秒为单位)等待的时间(以毫秒为单位)。如果紧接在报告为 “up” 的链路之后的期间内丢失了一些饱和的
ARP 请求
,则可以使用这一延迟。例如,可以在切换初始化时发生这种情况。 - 链接延迟
- 当之前活动链接报告为 “down” 时,在更改为另一个链接之前要等待的时间(毫秒)。如果连接的交换机需要相对较长的时间才会更改为备份模式,则可以使用这一延迟。
- ARP
- 地址解析协议
(ARP
)用于探测一个或多个同级服务器,以确定链路层连接的工作原理。它依赖于提供传输开始时间和上次接收时间的设备驱动程序。有两个可用的选项:- 监控频率
- 发送
ARP 请求之间的时间间隔
,以毫秒为单位。 - ARP 目标
- 用于发送
ARP
请求的IP 地址的逗号分隔列表
。
7.9. 其它资源
安装的文档
nmcli(1)
man page - 描述 NetworkManager 的命令行工具。nmcli-examples(5)
手册页 - 提供 nmcli 命令的示例.nm-settings(5)
手册页 - NetworkManager 连接的设置和参数的说明.
在线文档
- Red Hat Enterprise Linux 系统管理员指南
- 说明内核模块功能的使用情况。
- https://access.redhat.com/site/node/28421/Configuring_VLAN_devices_over_a_bonded_interface
- 有关通过绑定接口配置 VLAN 设备的红帽知识库文章。
第 8 章 配置网络合作
8.1. 了解网络合作
绑定
。网络合作这一术语已被选为指这个新的概念实施。现有绑定驱动程序不受影响,网络合作作为备选方式提供,不会替代 Red Hat Enterprise Linux 7 中的绑定。
libteam
库的应用守护进程 teamd
。一个 teamd
实例可以控制一个团队驱动程序实例。“守护进程通过使用称为运行程序的额外代码来实施负载平衡和” active-backup 逻辑,如循环。通过以这种方式隔离代码,网络合作实施提供了易于扩展且可扩展的解决方案,以满足负载平衡和冗余要求。例如,自定义运行程序可以相对轻松地编写以通过 teamd
实施新逻辑,即使 teamd
是可选的,用户可以自行编写应用以使用 libteam。
teamd
实例。teamdctl 围绕 teamd
D-Bus API 提供 D-Bus 打包程序。默认情况下,teamd
使用 Unix 域套接字侦听和通信,但仍监控 D-Bus。这是为了确保 teamd
可用于 D-Bus 不存在或尚未加载的环境中。例如,当通过 teamd
链接引导时,D-Bus 尚未加载。teamdctl 实用程序可在运行时用于读取配置、Link-watchers 状态、检查和更改端口状态、添加和删除端口,以及更改活动状态和备份状态之间的端口。
libteam
用户空间库不直接与 API 交互,而是使用 libnl 或 teamnl 与驱动程序 API 交互。
端口
也称为 从设备
。当 直接使用
teamd
时,首选使用 从
接口,而使用 NetworkManager 来指代创建组的接口。
8.2. 了解控制器和端口接口的默认行为
NetworkManager
守护进程控制合作端口接口时,特别是在查找故障时,请牢记以下几点:
- 启动控制器接口不会自动启动端口接口。
- 启动端口接口总会启动控制器接口。
- 停止控制器接口也会停止端口接口。
- 没有端口的控制器可以启动静态
IP
连接。 - 没有端口的控制器在启动
DHCP
连接时会等待端口。 - 当添加具有载波的端口时,等待端口且具有
DHCP
连接的控制器会完成。 - 当添加不具有载体的端口时,等待端口且具有
DHCP
连接的控制器将继续等待。
8.3. 网络团队与绑定的比较
功能 | bonding | Team |
---|---|---|
广播 Tx 策略 | 是 | 是 |
循环 Tx 策略 | 是 | 是 |
Active-backup Tx 策略 | 是 | 是 |
LACP(802.3ad)支持 | 是(仅活动) | 是 |
基于 hash 的 Tx 策略 | 是 | 是 |
用户可以设置哈希功能 | 否 | 是 |
TX 负载均衡支持(TLB) | 是 | 是 |
LACP 哈希端口选择 | 是 | 是 |
LACP 支持的负载均衡 | 否 | 是 |
ethtool 链接监控 | 是 | 是 |
ARP 链路监控 | 是 | 是 |
NS/NA(IPv6)链路监控 | 否 | 是 |
端口启动/关闭延迟 | 是 | 是 |
“端口优先级和粘性(主要选项增强” ) | 否 | 是 |
单独设置每个端口的链接监控设置 | 否 | 是 |
多个链路监控设置 | 有限 | 是 |
Lockless Tx/Rx 路径 | 否(rwlock) | 是(RCU) |
VLAN 支持 | 是 | 是 |
用户空间运行时控制 | 有限 | full |
用户空间中的逻辑 | 否 | 是 |
可扩展性 | 难 | 易 |
模块化设计 | 否 | 是 |
性能开销 | 低 | 非常低 |
D-Bus 接口 | 否 | 是 |
多设备堆栈 | 是 | 是 |
使用 LLDP 时零配置 | 否 | (在计划中) |
NetworkManager 支持 | 是 | 是 |
8.4. 了解网络合作后台程序和"运行者"
teamd
使用 libteam 来控制一个团队驱动程序实例。“这个团队驱动程序实例添加硬件设备驱动程序实例组成一个网络链接组”。团队驱动程序提供网络接口,team0 例如,到内核的其他部分:团队驱动程序实例创建的接口具有名称,如 team0,team1等等。这是为了便于理解,也可以使用其他名称。所有合作方法的常见逻辑都由 teamd
“实施;那些特定于不同负载共享和备份方法的功能(如循环)由称为运行程序的独立代码单元实施”。“由于模块和 ‘’ 模式等词语对内核已具有特定含义 ‘’,因此选择了运行程序一词来引用这些代码单元”。用户以 JSON 格式配置文件指定运行程序,然后在创建实例时将代码编译到 teamd
实例中。运行程序不是插件,因为运行程序的代码编译到 teamd
的实例中,因为它在创建之时。如果需要,可作为 teamd 的插件创建
。
- broadcast(数据通过所有端口传输)
- 循环(数据依次在所有端口上传输)
- Active-backup(使用一个端口或链接,而其他端口或链接作为备份)
- 负载均衡(具有活跃的 Tx 负载平衡和基于 BPF 的 Tx 端口选择器)
- LACP(实施 802.3ad 链接聚合控制协议)
- ethtool (Libteam lib 使用 ethtool 监视链接状态变化)。如果配置文件中未指定任何其他 link-watcher,则这是默认设置。
- arp_ping (arp_ping 实用程序用于监控使用 ARP 数据包的远端硬件地址是否存在。)
- nsna_ping (Neighbor Advertisements 和邻居请求来自
IPv6
Neighbor Discovery 协议)用于监控邻居接口的存在性。)
8.5. 安装网络合作守护进程
teamd
不会被安装。要安装 teamd
,以 root
用户身份运行以下命令:
~]# yum install teamd
8.6. 将 Bond 转换为团队
ifcfg
或 JSON 格式的团队配置文件。请注意,重命名后可能会中断防火墙规则、别名接口以及任何可能绑定到原始接口名称的任何内容,因为工具将仅更改 ifcfg
文件,而任何其他内容都不受影响。
~]$ bond2team --examples
新文件将在名称以 /tmp/bond2team.XXXXXX/ 开头的目录中创建,其中
XXXXXX 是随机字符串。创建新配置文件后,将旧绑定文件移动到备份文件夹,然后将新文件移到 /etc/sysconfig/network-scripts/
目录中。
例 8.1. 将 Bond 转换为团队
bond0
配置转换为 team ifcfg
,以 root 用户身份发出命令
:
~]# /usr/bin/bond2team --master bond0
请注意,这将保留名称 bond0。
要使用新名称保存配置,请使用 --rename
,如下所示:
~]# /usr/bin/bond2team --master bond0 --rename team0
添加 --json
选项以输出 JSON 格式文件,而不是 ifcfg
文件。有关 JSON 格式示例,请参阅 teamd.conf(5)
man page。
例 8.2. 将 Bond 转换为团队并指定文件路径
bond0
配置转换为团队 ifcfg
,并手动指定 ifcfg
文件的路径,以 root 身份发出命令
:
~]# /usr/bin/bond2team --master bond0 --configdir /path/to/ifcfg-file
添加 --json
选项以输出 JSON 格式文件,而不是 ifcfg
文件。
例 8.3. 使用 Bond2team 创建团队配置
~]# /usr/bin/bond2team --bonding_opts "mode=1 miimon=500"
您也可以在命令行中提供端口,如下:
~]# /usr/bin/bond2team --bonding_opts "mode=1 miimon=500 primary=enp1s0 \ primary_reselect-0" --port enp1s0 --port enp2s0 --port enp3s0 --port enp4s0
bond2team(1)
手册页。有关绑定参数的说明,请参阅 第 7.7 节 “使用频道绑定”
8.7. 选择用作网络组端口的接口
~]$ ip link show
1: lo: <LOOPBACK,UP,LOWER_UP > mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: em1: <BROADCAST,MULTICAST,UP,LOWER_UP > mtu 1500 qdisc pfifo_fast state UP mode DEFAULT qlen 1000
link/ether 52:54:00:6a:02:8a brd ff:ff:ff:ff:ff:ff
3: em2: <BROADCAST,MULTICAST,UP,LOWER_UP > mtu 1500 qdisc pfifo_fast state UP mode DEFAULT qlen 1000
link/ether 52:54:00:9b:6d:2a brd ff:ff:ff:ff:ff:ff
从可用接口中,确定哪些接口适合添加到您的网络团队,然后继续 第 8.8 节 “选择网络团队配置方法”
8.8. 选择网络团队配置方法
,teamd 将继续 第 8.10.2 节 “使用 teamd 创建网络团队”。
8.9. 使用文本用户界面 nmtui 配置网络团队
~]$ nmtui
此时将显示文本用户界面。任何无效的命令都会打印用法消息。
- 在起始菜单中选择 Edit a connection。选择 Add,这会打开 New Connection 屏幕。
图 8.1. NetworkManager 文本用户界面添加团队连接菜单
[D] - 选择 Team,打开 Edit connection 屏幕。
图 8.2. NetworkManager 文本用户界面配置团队连接菜单
[D] - 要向团队添加端口接口,请选择 Add,这会打开 New Connection 屏幕。选择连接类型后,选择创建按钮,使组的 Edit Connection 显示出现。
图 8.3. NetworkManager 文本用户界面配置新团队端口连接菜单
[D] - 在 Device 部分输入所需端口的设备名称或 MAC 地址。如果需要,通过选择 Show to the Ethernet 标签右侧输入要用作团队 MAC 地址的克隆 MAC 地址。选择确定按钮。注意如果设备没有 MAC 地址指定,则当 Edit Connection 窗口重新加载后,仅当成功找到该设备时,会自动填充 Device 部分。
图 8.4. NetworkManager 文本用户界面配置团队端口接口连接菜单
[D] - 合作端口的名称会出现在 Slaves 部分中。重复上述步骤,以添加其他端口连接。
- 如果要应用自定义端口设置,请选择 JSON 配置部分下的 Edit 按钮。这将启动可以应用更改的 vim 控制台。完成后,从 vim 写入更改,然后确认 JSON 配置下显示的 JSON 字符串是否与预期相符。
- 在选择确定按钮之前,检查并确认设置。
图 8.5. NetworkManager 文本用户界面配置团队连接菜单
[D]
8.10. 使用命令行配置网络团队
8.10.1. 使用 nmcli 配置网络合作
~]$ nmcli connection show
NAME UUID TYPE DEVICE
enp2s0 0e8185a1-f0fd-4802-99fb-bedbb31c689b 802-3-ethernet --
enp1s0 dfe1f57b-419d-4d1c-aaf5-245deab82487 802-3-ethernet --
~]$ nmcli device status
DEVICE TYPE STATE CONNECTION
virbr0 bridge connected virbr0
ens3 ethernet connected ens3
~]$ nmcli connection add type team ifname ServerA
Connection 'team-ServerA' (b954c62f-5fdd-4339-97b0-40efac734c50) successfully added.
NetworkManager 会将其内部参数 connection.autoconnect
设为 yes
,因为没有为 ipv4.method
指定任何 IP 地址
。
NetworkManager 还将配置文件写入 /etc/sysconfig/network-scripts/ifcfg-team-ServerA
,其中对应的 ONBOOT 设为 yes
,BOOTPROTO 将设置为 dhcp
。
~]$ nmcli con show team-ServerA connection.id: team-ServerA connection.uuid: b954c62f-5fdd-4339-97b0-40efac734c50 connection.interface-name: ServerA connection.type: team connection.autoconnect: yes … ipv4.method: auto [output truncated]由于没有指定 JSON 配置文件,因此应用默认值。如需有关团队 JSON 参数及其默认值的更多信息,请参阅
teamd.conf(5)
man page。请注意,名称是从接口名称中派生而来的,方法是在类型前附加。或者,使用 con-name
选项指定一个名称,如下所示:
~]$ nmcli connection add type team con-name Team0 ifname ServerB
Connection 'Team0' (5f7160a1-09f6-4204-8ff0-6d96a91218a7) successfully added.
~]$ nmcli con show
NAME UUID TYPE DEVICE
team-ServerA b954c62f-5fdd-4339-97b0-40efac734c50 team ServerA
enp2s0 0e8185a1-f0fd-4802-99fb-bedbb31c689b 802-3-ethernet --
enp1s0 dfe1f57b-419d-4d1c-aaf5-245deab82487 802-3-ethernet --
Team0 5f7160a1-09f6-4204-8ff0-6d96a91218a7 team ServerB
nmcli con mod old-team-name connection.id new-team-name
nmcli connection modify team-name team.config JSON-config
,您可以将团队配置指定为 JSON 字符串,或者提供包含配置的文件名。文件名可以包含路径。在这两种情况下,存储在 team.config
属性中的 JSON 字符串。如果是 JSON 字符串,请在字符串两边使用单引号,并将整个字符串粘贴到命令行。
team.config
属性: nmcli con show team-name | grep team.config
team.config
属性时,所有其他团队属性将相应地更新。
team.config
属性被更新为与新值匹配。
link -watchers 的 team.link
-watchers
属性,以以下格式输入命令: nmcli connection modify team-name team.link-watchers
"name=ethtool delay-up=5, name=nsna_ping target-host=target.host"
所需的 link-watchers
是用逗号分开的,并且属于同一 link-watcher
的属性由空格分隔。
team.runner
和 team.link-watchers
属性,以以下格式输入命令: nmcli connection modify team-name team.runner
activebackup team.link-watchers
"name=ethtool delay-up=5, name=nsna_ping target-host=target.host"
team.config
属性设置为对应的 JSON 字符串: nmcli connection modify team-name team.config
'{"runner": {"name": "activebackup"}, "link_watch": [{"name": "ethtool", "delay_up": 5},{"name": "nsna_ping", "target_host ": "target.host"}]'
Team0
,名称为 Team0-port1,请按以下方式发出命令:
~]$ nmcli con add type ethernet con-name Team0-port1 ifname enp1s0 slave-type team master Team0
Connection 'Team0-port1' (ccd87704-c866-459e-8fe7-01b06cf1cffc) successfully added.
~]$ nmcli con add type ethernet con-name Team0-port2 ifname enp2s0 slave-type team master Team0
Connection 'Team0-port2' (a89ccff8-8202-411e-8ca6-2953b7db52dd) successfully added.
nmcli 仅支持以太网端口。
~]$ nmcli connection up Team0-port1
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/2)
~]$ nmcli connection up Team0-port2
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/3)
~]$ ip link
3: Team0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT
link/ether 52:54:00:76:6f:f0 brd ff:ff:ff:ff:ff:f
另外,发出以下命令以打开团队,如下所示:
~]$ nmcli connection up Team0
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/4)
8.10.2. 使用 teamd 创建网络团队
root
特权运行的编辑器编辑这些文件。要列出可用的示例配置,请输入以下命令:
~]$ ls /usr/share/doc/teamd-*/example_configs/
activebackup_arp_ping_1.conf activebackup_multi_lw_1.conf loadbalance_2.conf
activebackup_arp_ping_2.conf activebackup_nsna_ping_1.conf loadbalance_3.conf
activebackup_ethtool_1.conf broadcast.conf random.conf
activebackup_ethtool_2.conf lacp_1.conf roundrobin_2.conf
activebackup_ethtool_3.conf loadbalance_1.conf roundrobin.conf
要查看包含的文件之一,如 activebackup_ethtool_1.conf
,请输入以下命令:
~]$ cat /usr/share/doc/teamd-*/example_configs/activebackup_ethtool_1.conf
{
"device": "team0",
"runner": {"name": "activebackup"},
"link_watch": {"name": "ethtool"},
"ports": {
"enp1s0": {
"prio": -10,
"sticky": true
},
"enp2s0": {
"prio": 100
}
}
}
创建用于存储 teamd
配置文件的工作配置目录。例如,作为普通用户,输入带有以下格式的命令:
~]$ mkdir ~/teamd_working_configs
将您选择的文件复制到您的工作目录中,并根据需要进行编辑。例如,您可以使用带有以下格式的命令:
~]$ cp /usr/share/doc/teamd-*/example_configs/activebackup_ethtool_1.conf \ ~/teamd_working_configs/activebackup_ethtool_1.conf
要编辑该文件以适应您的环境,例如要将接口更改为网络团队的端口,请打开该文件以进行编辑,如下所示:
~]$ vi ~/teamd_working_configs/activebackup_ethtool_1.conf
进行任何必要的更改并保存文件。有关使用 vi 编辑器或使用您首选编辑器的帮助,请参见 vi (1)
手册页。
~]$ ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: em1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP mode DEFAULT qlen 1000
link/ether 52:54:00:d5:f7:d4 brd ff:ff:ff:ff:ff:ff
3: em2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP mode DEFAULT qlen 1000
link/ether 52:54:00:d8:04:70 brd ff:ff:ff:ff:ff:ff
在本示例中,我们计划使用的接口都是 “UP”。
root
用户身份以以下格式发出命令:
~]# ip link set down em1
根据需要为每个接口重复此操作。
root
用户身份基于配置文件创建组接口,请更改到工作配置目录(本例中为teamd_working_configs ):
~]# cd /home/userteamd_working_configs
然后以以下格式发出命令:
~]# teamd -g -f activebackup_ethtool_1.conf -d
Using team device "team0".
Using PID file "/var/run/teamd/team0.pid"
Using config file "/home/user/teamd_working_configs/activebackup_ethtool_1.conf"
g 选项用于调试消息
,-f
选项指定要加载的配置文件,而 -d
选项则使进程在启动后作为守护进程运行。有关其他选项,请参阅 teamd(8)
手册页。
root
身份运行以下命令:
~]# teamdctl team0 state
setup:
runner: activebackup
ports:
em1
link watches:
link summary: up
instance[link_watch_0]:
name: ethtool
link: up
em2
link watches:
link summary: up
instance[link_watch_0]:
name: ethtool
link: up
runner:
active port: em1
root
用户身份以以下格式发出命令:
~]# ip addr add 192.168.23.2/24 dev team0
~]$ ip addr show team0
4: team0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP
link/ether 16:38:57:60:20:6f brd ff:ff:ff:ff:ff:ff
inet 192.168.23.2/24 scope global team0
valid_lft forever preferred_lft forever
inet6 2620:52:0:221d:1438:57ff:fe60:206f/64 scope global dynamic
valid_lft 2591880sec preferred_lft 604680sec
inet6 fe80::1438:57ff:fe60:206f/64 scope link
valid_lft forever preferred_lft forever
root
用户身份以以下格式发出命令:
~]# ip link set dev team0 up
root
用户身份以以下格式发出命令:
~]# ip link set dev team0 down
root
用户身份终止或终止团队守护进程实例,以以下格式发出命令:
~]# teamd -t team0 -k
k
选项指定与设备关联的守护进程实例 team0 将被终止。有关其他选项,请参阅 teamd(8)
手册页。
teamd
命令行选项的帮助,请运行以下命令:
~]$ teamd -h
此外,请参阅 teamd(8)man
page。
8.10.3. 使用 ifcfg 文件创建网络团队
ifcfg
文件创建网络团队,请在 /etc/sysconfig/network-scripts/
目录中创建一个文件,如下所示:
DEVICE=team0 DEVICETYPE=Team ONBOOT=yes BOOTPROTO=none IPADDR=192.168.11.1 PREFIX=24 TEAM_CONFIG='{"runner": {"name": "activebackup"}, "link_watch": {"name": "ethtool"}}'这会为团队创建接口,换句话说是
主设备
。
/etc/sysconfig/network-scripts/
目录中创建一个或多个文件,如下所示:
DEVICE=enp1s0 HWADDR=D4:85:64:01:46:9E DEVICETYPE=TeamPort ONBOOT=yes TEAM_MASTER=team0 TEAM_PORT_CONFIG='{"prio": 100}'根据需要添加与上述类似的额外端口接口,更改 DEVICE 和 HWADDR 字段以匹配正在添加的端口(网络设备)。如果未由
prio
指定端口优先级,则默认为 0
;它接受范围 -32,767 到 +32,767
的负值和正数。
root
用户身份运行以下命令:
~]# ifup team0
要查看网络团队,请运行以下命令:
~]$ ip link show
8.10.4. 使用 iputils 向网络团队添加端口
root
用户身份运行以下命令:
~]# ip link set dev em1 down ~]# ip link set dev em1 master team0根据需要添加其他端口。组驱动程序将自动启动端口。
8.10.5. 使用 teamnl 列出团队的端口
root
用户身份运行以下命令:
~]# teamnl team0 ports
em2: up 100 fullduplex
em1: up 100 fullduplex
8.10.6. 使用 teamnl 配置团队选项
root
用户身份运行以下命令:
~]# teamnl team0 options
要将团队配置为使用活跃备份模式,以 root
用户身份运行以下命令:
~]# teamnl team0 setoption mode activebackup
8.10.7. 使用 iputils 为网络团队添加地址
root
用户身份运行以下命令:
~]# ip addr add 192.168.252.2/24 dev team0
8.10.8. 使用 iputils 打开网络团队的接口
root
用户身份运行以下命令:
~]# ip link set team0 up
8.10.9. 使用 teamnl 查看团队的活跃端口选项
activeport
选项,以 root
用户身份运行以下命令:
~]# teamnl team0 getoption activeport
0
8.10.10. 使用 teamnl 设置团队的活跃端口选项
activeport
选项,以 root
用户身份运行以下命令:
~]# teamnl team0 setoption activeport 5
要检查团队端口选项中的更改,以 root
用户身份运行以下命令:
~]# teamnl team0 getoption activeport
5
8.11. 使用 teamdctl 控制 teamd
teamd
实例以获取统计信息或配置信息,或者进行更改,需要使用控制工具 teamdctl。
root
用户身份输入以下命令:
~]# teamdctl team0 state view
要获得更详细的输出:
~]# teamdctl team0 state view -v
~]# teamdctl team0 state dump
~]# teamdctl team0 config dump
~]# teamdctl team0 port config dump em1
8.11.1. 添加端口到网络团队
root
身份运行以下命令:
~]# teamdctl team0 port add em1
teamdctl
添加端口,则必须将端口设为 down。否则,teamdctl team0 端口添加 em1 命令将失败。
8.11.2. 从网络团队中删除端口
root
身份运行以下命令:
~]# teamdctl team0 port remove em1
8.11.3. 将配置应用到网络组中的端口
root
用户身份以以下格式发出命令:
~]# teamdctl team0 port config update em1 JSON-config-string
其中 JSON-config-string 是 JSON 格式作为文本字符串的配置。这将使用提供的 JSON 格式字符串更新端口的配置。配置端口的有效 JSON 字符串示例如下:
{ "prio": -10, "sticky": true }在 JSON 配置字符串两边使用单引号,并省略换行符。
teamdctl(8)手册页
。
8.11.4. 查看网络团队中的端口配置
root
身份运行以下命令:
~]# teamdctl team0 port config dump em1
这会将端口的 JSON 格式配置转储到标准输出。
8.12. 验证冗余的网络配置合作
流程
- 从组接口 Ping 目标 IP。例如:
~]# ping -I team0 DSTADDR
- 查看处于
活跃
模式的接口:~]# teamdctl team0 state setup: runner: activebackup ports: enp1s0 link watches: link summary: up instance[link_watch_0]: name: ethtool link: up down count: 0 enp2s0 link watches: link summary: up instance[link_watch_0]: name: ethtool link: up down count: 0 runner: active port: enp1s0
enp1s0 是活动
接口。 - 设置
活跃
端口接口缩减:~]# ip link set enp1s0 down
- 检查
备份
接口是否已启动:~]# teamdctl team0 state setup: runner: activebackup ports: enp1s0 link watches: link summary: down instance[link_watch_0]: name: ethtool link: down down count: 1 enp2s0 link watches: link summary: up instance[link_watch_0]: name: ethtool link: up down count: 0 runner: active port: enp2s0
enp2s0 现在是活动
接口。 - 检查您是否仍然可以从团队接口 ping 目标 IP:
~]# ping -I team0 DSTADDR
8.13. 配置 teamd 运行程序
teamd
运行程序介绍,请参阅 第 8.4 节 “了解网络合作后台程序和"运行者"”。
8.13.1. 配置广播运行程序
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": {"name": "broadcast"}, "ports": {"em1": {}, "em2": {}} }
teamd.conf(5)
手册页。
8.13.2. 配置随机运行程序
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": {"name": "random"}, "ports": {"em1": {}, "em2": {}} }
teamd.conf(5)
手册页。
8.13.3. 配置 round-robin Runner
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": {"name": "roundrobin"}, "ports": {"em1": {}, "em2": {}} }循环的非常基本配置.
teamd.conf(5)
手册页。
8.13.4. 配置 activebackup Runner
{ "device": "team0", "runner": { "name": "activebackup" }, "link_watch": { "name": "ethtool" }, "ports": { "em1": { "prio": -10, "sticky": true }, "em2": { "prio": 100 } } }这个示例配置使用以 ethtool 作为链路监视器的 active-backup 运行程序。端口 em2 具有更高优先级。sticky 标志可确保如果 em1 变为活动状态,只要链接保持启动,它就会保持活动状态。
{ "device": "team0", "runner": { "name": "activebackup" }, "link_watch": { "name": "ethtool" }, "ports": { "em1": { "prio": -10, "sticky": true, "queue_id": 4 }, "em2": { "prio": 100 } } }这个示例配置添加了队列 ID
4
。它使用 active-backup 运行程序,并将 ethtool 用作链路监视器。端口 em2 具有更高优先级。但是粘滞标志可确保如果 em1 变为活动状态,只要链接保持启动,它就会保持活动状态。
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": { "name": "activebackup" }, "link_watch": { "name": "ethtool", "delay_up": 2500, "delay_down": 1000 }, "ports": { "em1": { "prio": -10, "sticky": true }, "em2": { "prio": 100 } } }这个示例配置使用以 ethtool 作为链路监视器的 active-backup 运行程序。端口 em2 具有更高优先级。但是粘滞标志可确保如果 em1 变为活动状态,它在链接保持启动时保持活动状态。链接更改不会立即传播到运行程序,但会应用延迟。
teamd.conf(5)
手册页。
8.13.5. 配置 loadbalance Runner
teamd
干预即可完成负载共享。
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": { "name": "loadbalance", "tx_hash": ["eth", "ipv4", "ipv6"] }, "ports": {"em1": {}, "em2": {}} }配置基于哈希的被动传输(Tx)负载平衡.
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": { "name": "loadbalance", "tx_hash": ["eth", "ipv4", "ipv6"], "tx_balancer": { "name": "basic" } }, "ports": {"em1": {}, "em2": {}} }使用基本负载平衡器进行活动传输(Tx)负载平衡的配置。
teamd.conf(5)
手册页。
8.13.6. 配置 LACP(802.3ad)运行程序
root
用户身份使用编辑器,将以下内容添加到团队 JSON 格式配置文件中:
{ "device": "team0", "runner": { "name": "lacp", "active": true, "fast_rate": true, "tx_hash": ["eth", "ipv4", "ipv6"] }, "link_watch": {"name": "ethtool"}, "ports": {"em1": {}, "em2": {}} }用于连接到支持链路聚合控制协议(LACP )的对应对象的连接配置。LACP 运行程序应使用 ethtool 来监控链接的状态。请注意,只有 ethtool 可用于链路监控,因为如果是 arp_ping,链接永远不会出现。原因在于,必须首先建立链接,且只能在数据包(包括 ARP)之后才能进行。使用 ethtool 可以防止这种情况,因为它单独监控每个链路层。
"tx_balancer": { "name": "basic" }
teamd.conf(5)
手册页。
8.13.7. 配置链路状态的监控
root
特权运行的编辑器,将 JSON 格式字符串添加到团队 JSON 格式配置文件。
8.13.7.1. 配置 Ethtool 进行链接状态监控
"link_watch": { "name": "ethtool", "delay_up": 2500 }
"link_watch": { "name": "ethtool", "delay_down": 1000 }
8.13.7.2. 为链路状态监控配置 ARP Ping
teamd
将 ARP REQUEST 发送到链路远程末尾的地址,以确定链接是否已启动。使用的方法与 arping 实用程序相同,但它不使用该实用程序。
{ "device": "team0", "runner": {"name": "activebackup"}, "link_watch":{ "name": "arp_ping", "interval": 100, "missed_max": 30, "source_host": "192.168.23.2", "target_host": "192.168.23.1" }, "ports": { "em1": { "prio": -10, "sticky": true }, "em2": { "prio": 100 } } }此配置使用 arp_ping 作为链路监视器。
missing_max
选项是允许最多允许回复数的限值(例如,ARP 回复)。它应当与 interval
选项一同选择,以确定链接报告为 down 前的总时间。
root
用户身份运行以下命令:
~]# teamdctl port config update em2 JSON-config-file请注意,旧配置将被覆盖,省略的任何选项都将重置为默认值。有关更多团队守护进程控制工具命令示例,请参阅
teamdctl(8)手册页
。
8.13.7.3. 为 Link-state Monitoring 配置 IPv6 NA/NS
{ "device": "team0", "runner": {"name": "activebackup"}, "link_watch": { "name": "nsna_ping", "interval": 200, "missed_max": 15, "target_host": "fe80::210:18ff:feaa:bbcc" }, "ports": { "em1": { "prio": -10, "sticky": true }, "em2": { "prio": 100 } } }
"link_watch": { "name": "nsna_ping", "interval": 200 }值以毫秒为单位为正数。它应当与
missing_max
选项结合使用,以确定链接报告为 down 前的总时间。
"link_watch": { "name": "nsna_ping", "missed_max": 15 }丢失的 NS/NA 回复数据包的最大数量.如果超过这个数字,链接将报告为 down。
missing_max
选项是允许最多允许回复数的限值(例如,ARP 回复)。它应当与 interval
选项一同选择,以确定链接报告为 down 前的总时间。
IPv6
地址的主机名,请添加或编辑部分,如下所示:
"link_watch": { "name": "nsna_ping", "target_host": "MyStorage" }“target_host” 选项包含要转换为
IPv6 地址的主机名
,该地址将用作 NS/NA 数据包的目标地址。可以使用 IPv6
地址代替主机名。
teamd.conf(5)
手册页。
8.13.8. 配置端口选择覆盖
使用所选团队模式(teamd
运行程序)的策略选择输出端口。但默认情况下,将特定类别的传出流量定向到某些物理接口以实施略为复杂的策略会很有帮助。默认情况下,团队驱动程序是 multiqueue aware,并在驱动程序初始化时创建 16 个队列。如果需要更多或更少的队列,则可以使用 Netlink 属性 tx_queues 在创建团队驱动程序实例期间更改此值。
queue_id
设置,如下所示:
{ "queue_id": 3 }这些队列 ID 可与 tc 实用程序结合使用,以配置多队列队列强制和过滤器,以抑制要传输在特定端口设备上的某些流量。例如,如果使用上述配置并希望强制绑定到
192.168.1.100
的所有流量都使用 enp1s0 在团队的输出设备中,以以下格式以 root
身份发出命令:
~]# tc qdisc add dev team0 handle 1 root multiq ~]# tc filter add dev team0 protocol ip parent 1: prio 1 u32 match ip dst \ 192.168.1.100 action skbedit queue_mapping 3这种覆盖运行程序选择逻辑的机制以便绑定到特定端口的流量可以用于所有运行程序。
8.13.9. 配置基于 BPF 的 Tx Port Selectors
eth
- 使用源和目标 MAC 地址。VLAN
- 使用 VLAN ID。ipv4
- 使用源和目标IPv4
地址。ipv6
- 使用源和目标IPv6
地址。ip
- 使用源和目标IPv4
和IPv6
地址。l3
- 使用源和目标IPv4
和IPv6
地址。TCP
- 使用源和目标TCP
端口。UDP
- 使用源和目标UDP
端口。SCTP -
使用源和destinationSCTP
端口。l4
- 使用源和目标TCP
,以及UDP
和SCTP
端口。
"tx_hash": ["eth", "ipv4", "ipv6"]请参阅 第 8.13.5 节 “配置 loadbalance Runner”。
8.14. 使用 GUI 创建网络团队
8.14.1. 建立团队连接
过程 8.1. 使用 nm-connection-editor 添加新团队连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 单击添加按钮。此时将显示 Choose a Connection Type 窗口。选择 Team,再单击 Create。此时将显示 Editing Team connection 1 窗口。
图 8.6. NetworkManager 图形用户界面添加菜单
[D] - 在 Team 选项卡上,点 并选择您要用于团队连接的界面类型。 。请注意,仅当您创建第一个端口时才会出现选择端口类型的对话框;之后,它将自动将同一类型用于所有后续端口。
- 此时将显示 Editing team0 slave 1 窗口。
图 8.7. NetworkManager 图形用户界面添加
Slave
连接
[D] - 如果要应用自定义端口设置,请单击 Team Port 选项卡,再输入 JSON 配置字符串或从文件中导入。
- 单击按钮。
- 团队端口的名称会出现在 Teamed connections 窗口中。 。
- 检查并确认设置,然后单击保存按钮。
- 通过引用以下 第 8.14.1.1 节 “配置 Team 选项卡” 来编辑特定于团队的设置。
过程 8.2. 编辑现有团队连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 选择您要编辑的连接并点击 Edit 按钮。
- 选择常规选项卡。
- 编辑对话框中的五个设置对大多数连接类型很常见。请参见 General 选项卡:
- 连接名称 - 输入您的网络连接描述性名称。此名称用于在 Network 窗口的菜单中列出此连接。
- 自动激活的连接优先级 - 如果连接被设置为自动连接,则激活该数字(默认为
0
)。数值越高,表示优先级更高。 - 当这个网络可用时自动连接到这个网络 - 如果您希望 NetworkManager 在可用时自动连接到这个连接,请选择这个框。如需更多信息,请参阅 “使用 control-center 编辑现有连接”一节。
- 所有用户可以连接到此网络 - 选择此框可创建系统上所有用户可用的连接。更改此设置可能需要 root 特权。详情请查看 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
- 使用这个连接时自动连接到 VPN - 如果您希望 NetworkManager 在有可用时自动连接到 VPN 连接,请选择这个框。从下拉菜单中选择 VPN。
- firewall Zone - 从下拉菜单中选择防火墙区域。有关防火墙区域的更多信息,请参阅Red Hat Enterprise Linux 7 安全指南。
- 通过引用以下 第 8.14.1.1 节 “配置 Team 选项卡” 来编辑特定于团队的设置。
保存您的新(或修改)连接并创建进一步配置
- 或者
8.14.1.1. 配置 Team 选项卡
8.15. 其它资源
安装的文档
teamd(8)手册页
- 描述teamd
服务。teamdctl(8)手册页
- 描述teamd 管理工具
。teamd.conf(5)
手册页 - 描述teamd
配置文件。teamnl(8)手册页
- 描述teamd
Netlink 库。bond2team(1)
手册页 - 描述将绑定选项转换为 team 的工具。
在线文档
第 9 章 配置网络桥接
9.1. 使用文本用户界面 nmtui 配置桥接
~]$ nmtui
此时将显示文本用户界面。任何无效的命令都会打印用法消息。
- 在起始菜单中选择 Edit a connection。选择 Add,这会打开 New Connection 屏幕。
图 9.1. NetworkManager 文本用户界面添加网桥连接菜单
[D] - 选择 Bridge,会打开 Edit 连接屏幕。
- 要向网桥添加端口接口,请选择 Add,打开 New Connection 屏幕。选择连接类型后,选择创建按钮,使网桥的 Edit Connection 显示出现。
图 9.2. NetworkManager 文本用户界面添加了新的 Bridge
Slave
Connection 菜单
[D] - 在 Device 部分输入所需端口的设备名称或 MAC 地址。如果需要,通过在以太网标签右侧选择 Show 来输入要用作网桥 MAC 地址的克隆 MAC 地址。选择确定按钮。注意如果设备没有 MAC 地址指定,则当 Edit Connection 窗口重新加载后,仅当成功找到该设备时,会自动填充 Device 部分。
图 9.3. NetworkManager 文本用户界面配置 Bridge
Slave
Connection 菜单
[D] - 网桥端口的名称会出现在 Slaves 部分中。重复上述步骤,以添加其他端口连接。
- 在选择确定按钮之前,检查并确认设置。
图 9.4. NetworkManager 文本用户界面配置网桥菜单
[D]
9.2. 使用 NetworkManager 命令行工具 nmcli
root 身份发出命令
:
~]# nmcli con add type bridge ifname br0
Connection 'bridge-br0' (6ad5bba6-98a0-4f20-839d-c997ba7668ad) successfully added.
如果没有指定接口名称,名称将默认为 bridge,bridge-1,bridge-2等等。
~]$ nmcli con show
NAME UUID TYPE DEVICE
bridge-br0 79cf6a3e-0310-4a78-b759-bda1cc3eef8d bridge br0
enp1s0 4d5c449a-a6c5-451c-8206-3c9a4ec88bca 802-3-ethernet enp1s0
STP
,以 root
身份发出一个命令:
~]# nmcli con modify bridge-br0 bridge.stp no
要为此网桥重新启用 802.1D STP
,请以 root 身份发出命令
:
~]# nmcli con modify bridge-br0 bridge.stp yes
802.1D STP
的默认网桥优先级为 32768
。在 root 网桥选择中首选数值较低。例如,优先级为 28672
的网桥将被选为 root 网桥,而不是优先级为 32768
(默认值)的网桥。要使用非默认值创建桥接,请按如下所示发出命令:
~]$ nmcli con add type bridge ifname br5 stp yes priority 28672
Connection 'bridge-br5' (86b83ad3-b466-4795-aeb6-4a66eb1856c7) successfully added.
允许的值介于 0
到 65535
之间。
~]$ nmcli connection modify bridge-br5 bridge.priority 36864
允许的值介于 0
到 65535
之间。
:80:C2:00:00:00 到 01:80: C2:00:00
:0F
范围内转发组地址,请更改 group-forward-mask
属性。此属性是 16 位的掩码。每个位对应于上方必须转发的组地址。例如:
~]$ nmcli connection modify bridge-br5 bridge.group-forward-mask 8
group-forward-mask
属性无法将 0、
1、2
位中的任何一个设置为 1
,因为这些地址用于生成树协议(STP)、链路聚合控制协议(LACP)和以太网 MAC 暂停帧。
~]$ nmcli -f bridge con show bridge-br0
nmcli(1)
man page 的 bridge 部分列出了 802.1D STP
的其他选项。
~]$ nmcli con add type ethernet ifname enp1s0 master bridge-br0
Connection 'bridge-slave-enp1s0' (70ffae80-7428-4d9c-8cbd-2e35de72476e) successfully added.
- 更改其控制器和端口类型属性。例如,分配名为 vlan100 的现有 VLAN 连接:
~]$ nmcli connection modify vlan100 master bridge-br0 slave-type bridge
- 重新激活连接以应用更改:
~]$ nmcli connection up vlan100
~]$ nmcli connection edit bridge-br0
您将进入 nmcli 提示符。
nmcli> set bridge.priority 4096 nmcli> save Connection 'bridge-br0' (79cf6a3e-0310-4a78-b759-bda1cc3eef8d) successfully saved. nmcli> quit
9.3. 使用命令行界面(CLI)
9.3.1. 检查 Bridging 内核模块是否已安装
root
用户身份运行以下命令来确保载入该模块:
~]# modprobe --first-time bridge
modprobe: ERROR: could not insert 'bridge': Module already in kernel
要显示模块信息,请运行以下命令:
~]$ modinfo bridge
有关更多命令选项,请参阅 modprobe(8)手册页
。
9.3.2. 创建网桥
/etc/sysconfig/network-scripts/
目录中创建一个名为 ifcfg-brN
的文件,将 N 替换为接口的数字,如 0
。
DEVICE
指令以brN
格式指定接口名称作为其参数,其中 N 被接口编号取代。- 为
TYPE
指令指定参数Bridge
。此指令决定设备类型,参数区分大小写。 - 网桥接口配置文件被赋予一个
IP 地址
,而物理接口配置文件只能具有 MAC 地址(参见下方)。 - 添加了一个额外的指令
DELAY=0
,以防止该网桥在监控流量时等待该网桥,了解主机所在的位置,并构建 MAC 地址表,以基于该网桥的过滤决策。如果没有路由循环,则不需要 15 秒的默认延迟。
例 9.1. ifcfg-br0 接口配置文件示例
IP 地址的网桥接口配置文件示例
:
DEVICE=br0 TYPE=Bridge IPADDR=192.168.1.1 PREFIX=24 BOOTPROTO=none ONBOOT=yes DELAY=0
例 9.2. ifcfg-enp1s0 接口配置文件示例
/etc/sysconfig/network-scripts/ifcfg-device_name
中配置您的物理接口,其中 device_name 是接口的名称
DEVICE=device_name TYPE=Ethernet HWADDR=AA:BB:CC:DD:EE:FF BOOTPROTO=none ONBOOT=yes BRIDGE=br0
ifcfg-rh 将以
“Type Interface” 格式为连接配置集创建一个名称。在本例中,这意味着网桥将命名为 Bridge br0。
或者,如果 NAME=bridge-br0 添加到 ifcfg-br0
文件中,则连接配置集将命名为 bridge-br0。
DEVICE
指令,几乎可使用任何接口名称,因为它不能确定设备类型。TYPE=Ethernet
不严格要求。如果未设置 TYPE
指令,则该设备将被视为以太网设备(除非其名称明确匹配不同的接口配置文件)。
root
身份发出命令: ifup device
该命令将检测 NetworkManager 是否正在运行并调用 nmcli con load UUID,然后调用 nmcli con up UUID。
root
用户身份运行以下命令:
~]# systemctl restart network
此命令将停止网络服务,启动网络服务,然后为所有 ifcfg 文件调用 ifup,使用 ONBOOT=yes。
NetworkManager.conf
文件中的 monitor-connection-files
选项设置。如需更多信息,请参阅 NetworkManager.conf(5)
手册页。
9.3.3. 使用 Bond 的网桥
DEVICE=interface_name TYPE=Ethernet SLAVE=yes MASTER=bond0 BOOTPROTO=none HWADDR=AA:BB:CC:DD:EE:FF
将interface_name
用作接口名称是常见的做法,但几乎可以使用任何名称。
/etc/sysconfig/network-scripts/ifcfg-bond0
,如下所示:
DEVICE=bond0 ONBOOT=yes BONDING_OPTS='mode=1 miimon=100' BRIDGE=brbond0有关配置 bonding 模块和查看绑定参数列表的详情请参考 第 7.7 节 “使用频道绑定”。
/etc/sysconfig/network-scripts/ifcfg-brbond0
,如下所示:
DEVICE=brbond0 ONBOOT=yes TYPE=Bridge IPADDR=192.168.1.1 PREFIX=24
MASTER=bond0
指令。它们指向名为 /etc/sysconfig/network-scripts/ifcfg-bond0
的配置文件,其中包含 DEVICE=bond0
指令。此 ifcfg-bond0
依次指向包含 IP 地址的
/etc/sysconfig/network-scripts/ifcfg-brbond0
配置文件,并充当主机内虚拟网络的接口。
root
身份发出命令: ifup device
该命令将检测 NetworkManager 是否正在运行并调用 nmcli con load UUID,然后调用 nmcli con up UUID。
root
用户身份运行以下命令:
~]# systemctl restart network
此命令将停止网络服务,启动网络服务,然后为所有 ifcfg 文件调用 ifup,使用 ONBOOT=yes。
NetworkManager.conf
文件中的 monitor-connection-files
选项设置。如需更多信息,请参阅 NetworkManager.conf(5)
手册页。
9.4. 使用 GUI 配置网络桥接
IP
配置(如 DHCP
或 IPv6
“自动配置)前,会等待至少一个端口进入转发状态”。在连接端口或端口之前,可以在连接或开始转发数据包前执行静态 IP
寻址。
9.4.1. 使用 GUI 建立网桥连接
过程 9.1. 使用 nm-connection-editor 添加新网桥连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 单击添加按钮。此时将显示 Choose a Connection Type 窗口。选择 Bridge 并点 Create。此时会出现 Editing Bridge connection 1 窗口。
图 9.5. 编辑网桥连接 1
[D] - 通过下面的 过程 9.3, “在网桥中添加端口接口” 来添加端口设备。
过程 9.2. 编辑现有网桥连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 选择您要编辑的网桥连接。
- 单击编辑按钮。
配置连接名称、自动连接行为和可用性设置
- 连接名称 - 输入您的网络连接描述性名称。此名称将用于在 Network 窗口的菜单中列出此连接。
- 当这个网络可用时自动连接到这个网络 - 如果您希望 NetworkManager 在可用时自动连接到这个连接,请选择这个框。如需更多信息,请参阅 “使用 control-center 编辑现有连接”一节。
- 所有用户可以连接到此网络 - 选择此框可创建系统上所有用户可用的连接。更改此设置可能需要 root 特权。详情请查看 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
- 使用这个连接时自动连接到 VPN - 如果您希望 NetworkManager 在有可用时自动连接到 VPN 连接,请选择这个框。从下拉菜单中选择 VPN。
- 防火墙区域 - 从下拉菜单中选择防火墙区域。有关防火墙区域的更多信息,请参阅Red Hat Enterprise Linux 7 安全指南。
9.4.1.1. 配置 Bridge 选项卡
- 接口名称
- 网桥的接口名称。
- 桥接连接
- 个或多个端口接口。
- 老化时间
- MAC 地址的时间(以秒为单位)保存在 MAC 地址转发数据库中。
- 启用 IGMP 侦听
- 如果需要,选中复选框以在设备上启用 IGMP 侦听。
- 启用 STP(生成树协议)
- 如果需要,选择要启用
STP
的复选框。 - 优先级
- 优先级最低的网桥;将选择优先级最低的网桥作为根网桥。
- forward delay
- 在进入转发状态前,以秒为单位花费在列表和学习状态上的时间。默认值为 15 秒。
- 您好的时间
- 在网桥协议数据单元(BPDU)中发送配置信息之间的时间间隔,单位为秒。
- 最长期限
- 存储来自 BPDU 的配置信息的最长时间,以秒为单位。这个值应该是 Hello Time 和 1 的两倍,但小于转发延迟减号的两倍。
- 组转发掩码
- 此属性是组地址的掩码,允许转发组地址。在大多数情况下,将范围中的地址分组为
01:80:C2:00:00:00
到01:80:C2:00:00:0F
,不会由网桥设备转发。此属性是 16 位的掩码,各自对应于上述范围内的组地址,必须转发。请注意,组转发掩码
属性无法将0
、
1、2位中的任何一个设置为
1
,因为这些地址用于生成树协议(STP)、链路聚合控制协议(LACP)和以太网 MAC 暂停帧。
过程 9.3. 在网桥中添加端口接口
- 要向网桥添加端口,请在 Editing Bridge connection 1窗口中选择 Bridge 选项卡。如有必要,请按照 过程 9.2, “编辑现有网桥连接” 中的步骤打开此窗口。
- 点此时将显示 Choose a Connection Type 菜单。。
- 从列表中选择要创建的连接类型。点 Create。此时会显示适合所选连接类型的窗口。
图 9.6. NetworkManager 图形用户界面添加网桥连接
[D] - 选择"网桥端口"选项卡。根据需要配置优先级 和路径成本.请注意,网桥端口的 STP 优先级受 Linux 内核的限制。虽然标准允许
0
到 255 范围,
但 Linux 仅允许0
到255
。本例中默认为32
。图 9.7. NetworkManager 图形用户界面网桥端口选项卡
[D] - 如果需要,选中 Hairpin 模式复选框,以启用外部处理帧转发。也称为虚拟以太网端口聚合器 (VEPA)模式。
- 以太网端口,点击 以太网 选项卡并继续 “基本配置选项 ”一节 ;
- 绑定端口,点 Bond 选项卡并继续 第 7.8.1.1 节 “配置 Bond 选项卡” ;
- 团队端口,点击 团队 选项卡并继续 第 8.14.1.1 节 “配置 Team 选项卡” ;
- VLAN 端口,点 VLAN 选项卡,再继续 第 10.5.1.1 节 “配置 VLAN 选项卡” ;
保存您的新(或修改)连接并创建进一步配置
图 9.8. 带有 Bridge 的 NetworkManager 图形用户界面
[D]
9.5. 使用 iproute 配置以太网桥接配置
优先级
、成本
或 状态
。
ip
实用程序为分配给网桥设备的接口设置端口选项,以 root
身份运行以下命令:
~]# ip link set enp1s0 type bridge_slave option
ip
实用程序以 root
用户身份运行以下命令:
~]# ip link help bridge_slave
Usage: ... bridge_slave [ state STATE ] [ priority PRIO ] [cost COST ]
[ guard {on | off} ]
[ hairpin {on | off} ]
[ fastleave {on | off} ]
[ root_block {on | off} ]
[ learning {on | off} ]
[ flood {on | off} ]
有关端口选项的详情,请查看 ip-link(8)man
page。
9.6. 其它资源
nmcli(1)
man page - 描述 NetworkManager 的命令行工具。nmcli-examples(5)
手册页 - 提供 nmcli 命令的示例.nm-settings(5)
手册页 - NetworkManager 连接的设置和参数的说明.ip-link(8)手册页
- 网桥端口选项的描述.
第 10 章 配置 802.1Q VLAN 标记
- 对于绑定上的 VLAN,在打开 VLAN 接口之前,绑定具有端口且启动它们非常重要。“”在没有端口的绑定中添加 VLAN 接口无法正常工作。
- 无法在带有
fail_over_mac=follow
选项的绑定上配置 VLAN 端口,因为 VLAN 虚拟设备无法更改其 MAC 地址以匹配父 MAC 地址。在这种情况下,流量仍会与不正确的源 MAC 地址一同发送。 - 通过网络交换机发送 VLAN 标记的数据包需要正确配置交换机。例如,Cisco 交换机上的端口必须分配到一个 VLAN 或配置为中继端口,以接受来自多个 VLAN 的已标记数据包。某些供应商交换机允许通过中继端口处理原生 VLAN 的未标记帧。某些设备允许您启用或禁用原生 VLAN,其他设备则默认禁用它。因此,这种差异可能会导致两个不同交换机之间的原生 VLAN 配置错误,从而造成安全风险。例如:个交换机使用原生 VLAN 1 ,另一个交换机使用原生 VLAN 10。如果允许帧在不插入标签的情况下通过,攻击者可以跳过 VLAN - 这种常见的网络渗透技术也称为 VLAN 跳接。要最小化安全风险,请按以下方式配置接口:
- switch
- 除非需要它们,否则禁用中继端口。
- 如果您需要中继端口,请禁用原生 VLAN,以便不允许使用未标记的帧。
- Red Hat Enterprise Linux 服务器
- 使用 nftables or ebtables 实用程序在入口过滤中丢弃未标记帧。
- 些较旧的网络接口卡、环回接口、Wimax 卡和某些 InfiniBand 设备都被认为是 VLAN 挑战,这意味着它们不支持 VLAN。这通常是因为设备无法适应 VLAN 标头和与标记数据包关联的最大 MTU 大小。
10.1. 选择 VLAN 接口配置方法
- 要使用 NetworkManager 的文本用户界面工具 nmtui 配置 VLAN 接口,请继续 第 10.2 节 “使用文本用户界面 nmtui 配置 802.1Q VLAN 标记”
- 要使用 NetworkManager 的命令行工具 nmcli 配置 VLAN 接口,请继续 第 10.3 节 “使用命令行工具 nmcli 配置 802.1Q VLAN 标记”
- 要手动配置网络接口,请参阅 第 10.4 节 “使用命令行配置 802.1Q VLAN 标记”。
- 要使用图形用户界面工具配置网络,请继续 第 10.5 节 “使用 GUI 配置 802.1Q VLAN 标记”
10.2. 使用文本用户界面 nmtui 配置 802.1Q VLAN 标记
~]$ nmtui
此时将显示文本用户界面。任何无效的命令都会打印用法消息。
图 10.1. NetworkManager 文本用户界面添加 VLAN 连接菜单
[D]
图 10.2. NetworkManager 文本用户界面配置 VLAN 连接菜单
[D]
10.3. 使用命令行工具 nmcli 配置 802.1Q VLAN 标记
~]$ nmcli con show
NAME UUID TYPE DEVICE
System enp2s0 9c92fad9-6ecb-3e6c-eb4d-8a47c6f50c04 802-3-ethernet enp2s0
System enp1s0 5fb06bd0-0bb0-7ffb-45f1-d6edd65f3e03 802-3-ethernet enp1s0
请注意,输出中的 NAME 字段始终表示连接 ID。它不是接口名称,即使它可能看起来相同。该 ID 可用于 nmcli 连接命令来标识连接。将 DEVICE 名称用于其他应用,如 firewalld
。
10
,请发出以下命令:
~]$ nmcli con add type vlan ifname VLAN10 dev enp1s0 id 10
Connection 'vlan-VLAN10' (37750b4a-8ef5-40e6-be9b-4fb21a4b6d17) successfully added.
请注意,由于 VLAN 接口没有给出任何 con-name
,因此名称是通过在类型前前从接口名称派生而来的。或者,使用 con-name
选项指定一个名称,如下所示:
~]$ nmcli con add type vlan con-name VLAN12 dev enp1s0 id 12
Connection 'VLAN12' (b796c16a-9f5f-441c-835c-f594d40e6533) successfully added.
为 VLAN 接口分配地址
IPv4
地址和网关的 VLAN 接口的命令如下:
~]$ nmcli con add type vlan con-name VLAN20 dev enp1s0 id 20 ip4 10.10.10.10/24 \ gw4 10.10.10.254
~]$ nmcli con add type vlan con-name VLAN30 dev enp1s0 id 30
~]$ nmcli con show
NAME UUID TYPE DEVICE
VLAN12 4129a37d-4feb-4be5-ac17-14a193821755 vlan enp1s0.12
System enp2s0 9c92fad9-6ecb-3e6c-eb4d-8a47c6f50c04 802-3-ethernet enp2s0
System enp1s0 5fb06bd0-0bb0-7ffb-45f1-d6edd65f3e03 802-3-ethernet enp1s0
vlan-VLAN10 1be91581-11c2-461a-b40d-893d42fed4f4 vlan VLAN10
~]$ nmcli -p con show VLAN12 =============================================================================== Connection profile details (VLAN12) =============================================================================== connection.id: VLAN12 connection.uuid: 4129a37d-4feb-4be5-ac17-14a193821755 connection.interface-name: -- connection.type: vlan connection.autoconnect: yes … ------------------------------------------------------------------------------- 802-3-ethernet.port: -- 802-3-ethernet.speed: 0 802-3-ethernet.duplex: -- 802-3-ethernet.auto-negotiate: yes 802-3-ethernet.mac-address: -- 802-3-ethernet.cloned-mac-address: -- 802-3-ethernet.mac-address-blacklist: 802-3-ethernet.mtu: auto … vlan.interface-name: -- vlan.parent: enp1s0 vlan.id: 12 vlan.flags: 0 (NONE) vlan.ingress-priority-map: vlan.egress-priority-map: ------------------------------------------------------------------------------- =============================================================================== Activate connection details (4129a37d-4feb-4be5-ac17-14a193821755) =============================================================================== GENERAL.NAME: VLAN12 GENERAL.UUID: 4129a37d-4feb-4be5-ac17-14a193821755 GENERAL.DEVICES: enp1s0.12 GENERAL.STATE: activating [output truncated]
nmcli(1)
man page 的 VLAN 部分列出了 VLAN 命令的其他选项。在 man page 中,创建 VLAN 的设备称为父设备。在上面的示例中,设备通过其接口名称 enp1s0
指定,它也可以通过连接 UUID 或 MAC 地址来指定。
13
,发出如下命令:
~]$ nmcli con add type vlan con-name VLAN1 dev enp2s0 id 13 ingress "2:3,3:5"
~]$ nmcli connection show vlan-VLAN10
~]$ nmcli connection modify vlan-VLAN10 802.mtu 1496
MTU 设置决定了网络层数据包的最大大小。链路层帧可以附带的载荷的最大大小反过来限制了网络层 MTU。对于标准以太网帧,这意味着 MTU 为 1500 字节。设置 VLAN 时,无需更改 MTU,因为链路层标头的大小会增加 4 字节,以适应 802.1Q 标签。
connection.interface-name
和 vlan.interface-name
必须相同(如果已设置)。因此,必须使用 nmcli 的交互模式同时更改它们。要更改 VLAN 连接名称,请使用以下命令:
~]$ nmcli con edit vlan-VLAN10 nmcli> set vlan.interface-name superVLAN nmcli> set connection.interface-name superVLAN nmcli> save nmcli> quit
ioctl
标志,以改变 802.1Q 代码函数的方式。NetworkManager 支持以下 VLAN 标记:
- 0x01 - 重新排序输出数据包标头
- 0x02 - 使用 GVRP 协议
- 0x04 - 接口及其 master 的松散绑定
0x04
可启用 松散绑定 模式,其中仅操作状态从父对象传递到关联的 VLAN,但不更改 VLAN 设备状态。
~]$ nmcli connection modify vlan-VLAN10 vlan.flags 1
10.4. 使用命令行配置 802.1Q VLAN 标记
8021q
模块。如果需要,您可以以 root
用户身份运行以下命令来确保载入该模块:
~]# modprobe --first-time 8021q
modprobe: ERROR: could not insert '8021q': Module already in kernel
要显示模块信息,请运行以下命令:
~]$ modinfo 8021q
有关更多命令选项,请参阅 modprobe(8)手册页
。
10.4.1. 使用 ifcfg 文件设置 802.1Q VLAN 标记
- 在
/etc/sysconfig/network-scripts/ifcfg-device_name 中配置父接口
,其中 device_name 是接口的名称:DEVICE=interface_name TYPE=Ethernet BOOTPROTO=none ONBOOT=yes
- 在
/etc/sysconfig/network-scripts/
目录中配置 VLAN 接口配置。配置文件名称应当是父接口加上 a.
字符加上 VLAN ID 号。例如,如果 VLAN ID 为 192,并且父接口为 enp1s0,则配置文件名称应为ifcfg-enp1s0.192
:DEVICE=enp1s0.192 BOOTPROTO=none ONBOOT=yes IPADDR=192.168.1.1 PREFIX=24 NETWORK=192.168.1.0 VLAN=yes
如果需要在同一接口 enp1s0 上配置第二个 VLAN(如 VLAN ID 193),请添加一个名称为enp1s0.193
的新文件,并提供 VLAN 配置详细信息。 - 重新启动网络服务,以使更改生效。作为
root
发出以下命令:~]# systemctl restart network
10.4.2. 使用 ip 命令配置 802.1Q VLAN 标记
8
,请以 root 身份发出命令
,如下所示:
~]# ip link add link enp1s0 name enp1s0.8 type vlan id 8
要查看 VLAN,请运行以下命令:
~]$ ip -d link show enp1s0.8
4: enp1s0.8@enp1s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT
link/ether 52:54:00:ce:5f:6c brd ff:ff:ff:ff:ff:ff promiscuity 0
vlan protocol 802.1Q id 8 <REORDER_HDR>
0x
)和数值(如果具有前导 0
)。这意味着,若要分配一个十进制值为 22 的 VLAN ID ,
不得添加任何前导零。
root
身份发出命令,如下所示:
~]# ip link delete enp1s0.8
~]# ip link add link enp1s0 name enp1s0.1 type vlan id 1 ip link set dev enp1s0.1 up ~]# ip link add link enp1s0 name enp1s0.2 type vlan id 2 ip link set dev enp1s0.2 up
tcpdump -nnei enp1s0 -vvv
ifcfg
文件。请查看 第 10.4.1 节 “使用 ifcfg 文件设置 802.1Q VLAN 标记”
10.5. 使用 GUI 配置 802.1Q VLAN 标记
10.5.1. 建立 VLAN 连接
过程 10.1. 使用 nm-connection-editor 添加新 VLAN 连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 单击添加按钮。此时将显示 Choose a Connection Type 窗口。选择 VLAN 并单击 Create。此时将显示 Editing VLAN 连接 1 窗口。
- 在 VLAN 选项卡上,从您要用于 VLAN 连接的下拉列表中选择父接口。
- 输入 VLAN ID
- 输入 VLAN 接口名称。这是将要创建的 VLAN 接口的名称。例如,
enp1s0.1
或vlan2
。(通常这是父接口名称加上 “.
” 和 VLAN ID,或者 “vlan
” 加上 VLAN ID。) - 检查并确认设置,然后单击保存按钮。
- 要编辑特定于 VLAN 的设置,请参阅 第 10.5.1.1 节 “配置 VLAN 选项卡”。
图 10.3. 使用 nm-connection-editor 添加新 VLAN 连接
[D]
过程 10.2. 编辑现有的 VLAN 连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 选择您要编辑的连接并点击 Edit 按钮。
- 选择常规选项卡。
- 配置连接名称、自动连接行为和可用性设置。Editing 对话框中的这些设置对所有连接类型通用:
- 连接名称 - 输入您的网络连接描述性名称。此名称将用于在网络窗口的 VLAN 部分中列出此连接。
- 当这个网络可用时自动连接到这个网络 - 如果您希望 NetworkManager 在可用时自动连接到这个连接,请选择这个框。如需更多信息,请参阅 “使用 control-center 编辑现有连接”一节。
- 可供所有用户使用 - 选择此复选框创建系统上所有用户可用的连接。更改此设置可能需要 root 特权。详情请参考 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
- 要编辑特定于 VLAN 的设置,请参阅 第 10.5.1.1 节 “配置 VLAN 选项卡”。
保存您的新(或修改)连接并创建进一步配置
- 或者
10.5.1.1. 配置 VLAN 选项卡
- 父接口
- 可在下拉列表中选择之前配置的接口。
- VLAN ID
- 用于标记 VLAN 网络流量的标识号。
- VLAN 接口名称
- 要创建的 VLAN 接口的名称。例如,
enp1s0.1
或vlan2
。 - 克隆的 MAC 地址
- (可选)设置用于标识 VLAN 接口的备用 MAC 地址。这可用于更改在此 VLAN 上发送的数据包的源 MAC 地址。
- MTU
- (可选)设置用于通过 VLAN 连接发送的数据包的最大传输单元(MTU)大小。
10.6. 使用 ip 命令绑定和桥接上的 VLAN
- 以
root
用户身份添加绑定设备:# ip link add bond0 type bond # ip link set bond0 type bond miimon 100 mode active-backup # ip link set em1 down # ip link set em1 master bond0 # ip link set em2 down # ip link set em2 master bond0 # ip link set bond0 up
- 在绑定设备中设置 VLAN:
# ip link add link bond0 name bond0.2 type vlan id 2 # ip link set bond0.2 up
- 添加桥接设备并为其附加 VLAN:
# ip link add br0 type bridge # ip link set bond0.2 master br0 # ip link set br0 up
10.7. Bond 和 Bridge 上使用 NetworkManager 命令行工具 nmcli 的 VLAN
- 添加绑定设备:
~]$ nmcli connection add type bond con-name Bond0 ifname bond0 bond.options "mode=active-backup,miimon=100" ipv4.method disabled ipv6.method ignore
请注意,在这种情况下,绑定连接仅充当 VLAN 的"低接口",并且不获取任何 IP 地址。因此,已在命令行中禁用ipv4.method
忽略参数和ipv6.method
忽略参数。 - 在绑定设备中添加端口:
~]$ nmcli connection add type ethernet con-name Slave1 ifname em1 master bond0 slave-type bond ~]$ nmcli connection add type ethernet con-name Slave2 ifname em2 master bond0 slave-type bond
- 添加桥接设备:
~]$ nmcli connection add type bridge con-name Bridge0 ifname br0 ip4 192.0.2.1/24
- 在分配给网桥设备的绑定之上添加 VLAN 接口:
~]$ nmcli connection add type vlan con-name Vlan2 ifname bond0.2 dev bond0 id 2 master br0 slave-type bridge
- 查看创建的连接:
~]$ nmcli connection show NAME UUID TYPE DEVICE Bond0 f05806fa-72c3-4803-8743-2377f0c10bed bond bond0 Bridge0 22d3c0de-d79a-4779-80eb-10718c2bed61 bridge br0 Slave1 e59e13cb-d749-4df2-aee6-de3bfaec698c 802-3-ethernet em1 Slave2 25361a76-6b3c-4ae5-9073-005be5ab8b1c 802-3-ethernet em2 Vlan2 e2333426-eea4-4f5d-a589-336f032ec822 vlan bond0.2
10.8. 配置 VLAN 切换端口模式
交换机并且通过物理接口运行 VLAN 时,您需要设置交换机端口模式
。红帽企业 Linux 服务器或工作站通常仅连接到一个 VLAN,这使得切换模式访问适合和默认设置
。
机器之间是以太网,这需要两端配置交换模式中继
。
switchport 模式中继
。如果您仅在接口上设置 IP 地址,请使用 Cisco switchport 模式访问
。
10.9. 其它资源
ip-link(8)手册页
- 描述 ip 实用程序的网络设备配置命令。nmcli(1)
man page - 描述 NetworkManager 的命令行工具。nmcli-examples(5)
手册页 - 提供 nmcli 命令的示例.nm-settings(5)
手册页 - NetworkManager 连接的设置和参数的说明.nm-settings-ifcfg-rh(5)
手册页 -/etc/sysconfig/network-scripts/ifcfg-* 文件中的 ifcfg-rh
设置的说明。
第 11 章 一致的网络设备命名
eth[0123…]s0
但是这些名称不一定与机箱上的实际标签对应。具有多个网络适配器的现代服务器平台,可能会遇到这些接口的命名不明确的情况。这会影响主板上嵌入的网络适配器(Lan-on-Motherboard 或LOM)和附加(单点和多端口)适配器。
ethX
样式名称,其中 X 是与特定接口对应的唯一编号,在引导过程中可能具有不同的网络接口名称。如需了解更多详细信息,请参阅 第 11.10 节 “网络设备命名故障排除”。
11.1. 命名方案层次结构
默认情况下,systemd
将使用以下策略命名接口以应用支持的命名方案:
- 方案 1 :合并固件或 BIOS 的名称提供板载设备的索引号(example:
eno1)
,如果固件或 BIOS 中的信息适用并可用,则应用该编号,否则返回方案 2。 - 方案 2 :合并固件或 BIOS 的名称提供 PCI Express 热插拔插槽指数号(
例如:ens1
)如果固件或 BIOS 中的信息适用并可用,则将应用,否则回退到方案 3。 - 方案 3 :合并硬件连接器的物理位置的名称(例如:
enp2s0
)会被应用(如果适用),否则在所有其他情况下直接回退到方案 5。 - 方案 4 :默认情况下不使用合并接口的 MAC 地址(例如:
enx78e7d1ea46da
),但如果用户选择,则可用。 - 方案 5 :传统的不可预测的内核命名方案(如果所有其他方法都失败)将使用 (例如:
enp1s0
)。
11.2. 了解设备重命名过程
/usr/lib/udev/rules.d/60-net.rules 中的规则指示
udev helper 实用程序 /lib/udev/rename_device 查看所有/etc/sysconfig/network-scripts/ifcfg-后缀文件
。如果找到具有与接口 MAC 地址匹配的 aHWADDR 条目的ifcfg
文件,它会将接口重命名为ifcfg
文件中由 DEVICE 指令指定的名称。/usr/lib/udev/rules.d/71-biosdevname.rules 中的规则指示
biosdevname 根据命名策略重命名接口,只要在上一步中未重命名该接口,则会安装 biosdevname,在引导命令行中未提供 biosdevname=0 作为内核命令。/lib/udev/rules.d/75-net-description.rules 中的规则指示
udev 通过检查网络接口设备来填写内部 udev 设备属性值 ID_NET_NAME_ONBOARD、ID_NET_NAME_SLOT、ID_NET_NAME_PATH、ID_NET_NAME_MAC。请注意,某些设备属性可能尚未定义。根据以下优先级,/usr/lib/udev/rules.d/80-net-name-slot.rules 中的规则指示
udev 重新命名该接口,但第 1 或 2 步中未对其进行重命名,且未提供内核参数 net.ifnames=0,这根据以下优先级:ID_NET_NAME_ONBOARD、ID_NET_NAME_SLOT、ID_NET_NAME_PATH。如果一个未设置,则会进入列表中的下一个。如果未设置这些接口,则不会重命名接口。
11.3. 了解可预测网络接口设备名称
以太网
,用于无线
局域网(WLAN),用于
无线局域网(WWAN)的 WW。
- O<index>
- 板载设备索引号
- s<slot>[f<function>][d<dev_id>]
- 热插拔插槽索引号.所有多功能 PCI 设备将在设备名称中承载
[f<功能>]
编号,包括功能0
设备。 - x<MAC>
- MAC 地址
- [P<domain>]p<bus>s<slot>[f<function>][d<dev_id>]
- PCI 地理位置.在 PCI 地理位置中,只有在值不是
0
时才会提及[P<domain>]
号。例如:ID_NET_NAME_PATH=P1enp5s0
- [P<domain>]p<bus>s<slot>[f<function>][u<port>][.][c<config>][i<interface>]
- USB 端口号链.对于 USB 设备,hub 端口号的完整链由 hub 的端口号组成。如果名称超过最多 15 个字符数,则不会导出该名称。如果链中有多个 USB 设备,则隐藏 USB 配置描述符
(c1)
和 USB 接口描述符(i0)
的默认值。
11.4. System z 上 Linux 可用的网络设备命名方案
0.n
,其中 n
是子频道集 ID。例如: 0.1.0ab1
。
enccw0.0.1234
slccw0.0.1234
格式 | 描述 |
---|---|
enccwbus-ID | 设备类型以太网 |
slccwbus-ID | 设备类型为 SLIP 的网络设备 |
11.5. VLAN 接口的命名方案
VLAN-ID
范围从 0
到 4096 个
,最多四个字符,接口名称总数则限制为 15 个字符。最大接口名称长度由内核标头定义,是一个全局限制,会影响所有应用程序。
- VLAN 加上 VLAN ID
- 单词
vlan
加上 VLAN ID。例如:vlan0005 - VLAN 加上 VLAN ID 但不填充
- 通过额外的前导零,单词
vlan
加上 VLAN ID 而无需 padding。例如:vlan5 - 设备名称加上 VLAN ID
- 父接口的名称加上 VLAN ID。例如: enp1s0.0005
- 设备名称加上 VLAN ID,但不进行 padding
- 父接口的名称加上 VLAN ID 而无需通过额外的前导零进行 padding。例如: enp1s0.5。
11.6. 使用 biosdevname 的一致网络设备命名
eth[0123…]
表 11.2 “biosdevname 命名约定” 所示的新命名规则。请注意,除非系统是 Dell 系统,否则 biosdevname 被显式启用,如 第 11.6.2 节 “启用和禁用功能” 所述,systemd 命名方案将优先使用
。
设备 | 旧名称 | 新名称 |
---|---|---|
嵌入式网络接口(LOM) | eth[0123…] | em[1234…] [a] |
PCI 卡网络接口 | eth[0123…] | p<slot>p<以太网端口> [b] |
虚拟功能 | eth[0123…] | p<slot>p<以太网端口>_<虚拟接口> [c] |
[a]
新的枚举从 1 开始.
[b]
例如: p3p4
[c]
例如: p3p4_1
|
11.6.1. 系统要求
root
身份运行以下命令:
~]# yum install biosdevname
11.6.2. 启用和禁用功能
biosdevname=0
biosdevname=1
systemd
命名方案。
biosdevname
install 选项,它必须保留为系统生命周期的引导选项。
11.7. 管理员备注
irqbalance
的脚本和其他类似配置文件的网络接口名称。此外,启用此更改以进行安装需要修改通过 ksdevice
参数使用设备名称的现有 kickstart 文件;这些 kickstart 文件将需要更新,才能使用网络设备的 MAC 地址或网络设备的新名称。
11.8. 控制网络设备名称的选择
- 通过识别网络接口设备
- 使用HWADDR 指令在
ifcfg
文件中设置 MAC 地址可使其由 udev 标识。名称取自 DEVICE 指令提供的字符串,按照惯例,该字符串与ifcfg
后缀相同。例如,ifcfg
-enp1s0。 - 通过打开或关闭 biosdevname
- 将使用 biosdevname 提供的名称(如果 biosdevname 可以确定一个名称)。
- 通过打开或关闭
systemd-udev
命名方案 - 将使用
systemd-udev
提供的名称(如果systemd-udev
可以确定一个名称)。
11.9. 禁用一致的网络设备命名
- 通过"masking"udev 的默认策略的规则文件禁用分配固定名称。这可以通过创建指向
/dev/null
的符号链接来完成。因此,将使用无法预测的内核名称。以root
用户身份输入以下命令:~]# ln -s /dev/null /etc/udev/rules.d/80-net-name-slot.rules
- 创建您自己的手动命名方案,例如命名您的接口
internet0
、dmz0
orlan0。
为此,请创建自己的 udev 规则文件,并为设备设置 NAME 属性。确保对默认策略文件上方的新文件进行排序,例如为其命名/etc/udev/rules.d/70-my-net-names.rules
。 - 更改默认策略文件以选择不同的命名方案,例如,默认为 MAC 地址后命名所有接口。作为
root 用户
,复制默认策略文件,如下所示:~]# cp /usr/lib/udev/rules.d/80-net-name-slot.rules /etc/udev/rules.d/80-net-name-slot.rules
编辑/etc/udev/rules.d/ 目录中的文件并根据需要更改行
。 - 打开
/etc/default/grub
文件并查找GRUB_CMDLINE_LINUX
变量。 将注意GRUB_CMDLINE_LINUX
是一个变量,其中包含添加到内核命令行中的条目。它可能已经包含其他配置,具体取决于您的系统设置。net.ifnames=0
和biosdevname=0
作为内核参数值添加到GRUB_CMDLINE_LINUX
变量:~]# cat /etc/default/grub GRUB_TIMEOUT=5 GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc/system-release)" GRUB_DEFAULT=saved GRUB_DISABLE_SUBMENU=true GRUB_TERMINAL_OUTPUT="console" GRUB_CMDLINE_LINUX="rd.lvm.lv=rhel_7/swap rd.luks.uuid=luks-cc387312-6da6-469a-8e49-b40cd58ad67a crashkernel=auto vconsole.keymap=us vconsole.font=latarcyrheb-sun16 rd.lvm.lv=rhel_7/root rhgb quiet net.ifnames=0 biosdevname=0" GRUB_DISABLE_RECOVERY="true"
运行 grub2-mkconfig 命令重建/boot/grub2/grub.cfg
文件:~]# grub2-mkconfig -o /boot/grub2/grub.cfg
注意对于使用 UEFI 引导的系统:~]# grub2-mkconfig -o /boot/efi/EFI/redhat/grub.cfg
查看当前的设备名称。例如,eno1:~]# nmcli connection show NAME UUID TYPE DEVICE Wired 63cba8b2-60f7-4317-bc80-949e800a23cb 802-3-ethernet eno1
将设备名称修改为 enp1s0,并重启系统:~]# nmcli connection modify Wired connection.interface-name enp1s0
~]# reboot
grubby 实用程序用于更新和显示关于grub
引导加载器的配置文件的信息。详情请查看grubby(8)
手册页。有关使用 GRUB2 的更多信息,请参阅 Red Hat Enterprise Linux 系统管理员指南。
11.10. 网络设备命名故障排除
root 用户身份以以下格式发出命令
:
~]# udevadm info /sys/class/net/ifname | grep ID_NET_NAME
其中 ifname 是以下命令列出的接口之一:
~]$ ls /sys/class/net/
/usr/lib/udev/rules.d/60-net.rules
- 从 initscripts 开始,/usr/lib/udev/rules.d/71-biosdevname.rules
- from biosdevname,/usr/lib/udev/rules.d/80-net-name-slot.rules
- fromsystemd
80-net-name-slot.rules
从 /usr
复制到 /etc
,并相应地编辑该文件。换句话说,注释掉或安排按特定顺序使用的方案。
例 11.1. 某些接口来自内核命名空间(eth[0,1,2...]),而 Others Are Successfully Renamed 为 udev
例 11.2. 在 /var/log/messages 或 systemd Journal 中,Renaming Is Seen to Be Done Twice for E每个接口
文件中编码,但没有重新生成的 initrd
镜像可能会遇到这个问题。在早期启动期间,仍使用 initrd
分配接口名称(通过 biosdevname 或 udev 或 dracut 参数)。然后,在切换到真实 rootfs
后,将再次执行重命名,并且新接口名称由 udev 生成的 /usr/lib/udev/rename_device
二进制文件决定,因为需要处理 60-net.rules。您可以安全地忽略此类消息。
例 11.3. 在 ifcfg 文件中使用 ethX 名称不起作用的命名方案
/usr/lib/udev/rules.d/60-net.rules
文件提供的功能。
- 系统只有一个网络接口。
- 用于红帽企业 Linux 7 虚拟机中的 virtio NIC.请参阅《虚拟化部署和管理指南》中的 KVM 半虚拟化(virtio)驱动程序和网络配置章节
例 11.4. 在 Inconsistent enpXxX Names 中设置 net.ifnames=0 结果
systemd
可预测的接口命名(net.ifnames
)和 biosdevname 命名方案都已禁用,网络接口继续使用最初由内核提供的 ethX 名称无法预计且可能不一致。
systemd
可预测的接口命名方案或 biosdevname 命名方案,以可预测的方式将内核无法预计的 ethX 接口重命名为在重新引导后始终一致的名称。
例 11.5. 以太网接口前缀的限制
- 它由 ASCII 字符组成。
- 它是一个字母数字字符串。
- 它少于 16 个字符。
- 它不与用于网络接口命名的任何其他已知的前缀冲突,如
eth
、eno
、ens 和
em
。
11.11. 其它资源
安装的文档
udev(7)
手册页 - 描述 Linux 动态设备管理守护进程udevd
。systemd(1)
man page - 描述systemd
系统和服务管理器。biosdevname(1)
man page - 描述用于获取设备的 BIOS 给定名称的实用程序。
在线文档
- 红帽企业 Linux 7 上的 IBM 知识库 SC34-2710-00 设备驱动程序、功能和命令包括用于 IBM System z “设备和附加的可预测网络设备名称的信息”。
第 12 章 配置基于策略的路由来定义备用路由
nmcli
实用程序支持设置路由规则,并将路由分配到特定表。
12.1. 将流量从特定子网路由到不同的默认网关
图 12.1. 激活连接
先决条件
- 要在流程中设置的 RHEL 路由器有四个网络接口:
enp7s0
接口连接到供应商 A 的网络。提供商网络中的网关 IP 是198.51.100.2
,网络使用a/30
网络掩码。enp1s0
接口连接到提供商 B 的网络。提供商网络中的网关 IP 是192.0.2.2
网络掩码。,网络使用一个/30
enp8s0
接口通过内部工作站连接到10.0.0.0/24
子网。enp9s0
接口与公司的服务器一起连接到203.0.113.0/24
子网。
- 内部工作站子网中的主机使用
10.0.0.1
作为默认网关。在此过程中,您要将此 IP 地址分配给路由器的enp8s0
网络接口。 - 服务器子网中的主机使用
203.0.113.1
作为默认网关。在此过程中,您要将此 IP 地址分配给路由器的enp9s0
网络接口。 firewalld
服务已启用并激活,这是默认设置。
流程
- 将网络接口配置为供应商 A:
# nmcli connection add type ethernet con-name Provider-A ifname enp7s0 ipv4.method manual ipv4.addresses 198.51.100.1/30 ipv4.gateway 198.51.100.2 ipv4.dns 198.51.100.200 connection.zone external
nmcli connection add 命令创建 NetworkManager 连接配置集。以下列表描述了该命令的选项:键入 ethernet
:定义连接类型为 Ethernet。con-name connection_name
:设置配置集的名称。使用有意义的名称以避免混淆。ifname network_device
:设置网络接口。ipv4.method 手册
:启用配置静态 IP 地址。ipv4.addresses IP_address/subnet_mask
:设置 IPv4 地址和子网掩码。ipv4.gateway IP_address
:设置默认网关地址。ipv4.dns IP_of_DNS_server
:设置 DNS 服务器的 IPv4 地址。connection.zone firewalld_zone
:将网络接口分配给定义的firewalld
区域。请注意,firewalld
自动启用分配给外部区的伪装接口。
- 将网络接口配置为供应商 B:
# nmcli connection add type ethernet con-name Provider-B ifname enp1s0 ipv4.method manual ipv4.addresses 192.0.2.1/30 ipv4.routes "0.0.0.0/1 192.0.2.2 table=5000, 128.0.0.0/1 192.0.2.2 table=5000" connection.zone external
这个命令使用ipv4.routes
参数而不是ipv4.gateway
来设置默认网关。这需要将此连接的默认网关分配到不同于默认值的路由表(5000)。当连接被激活时,NetworkManager 会自动创建这个新的路由表。注意nmcli
实用程序不支持将0.0.0.0/0
用于ipv4.gateway
中的默认网关。为临时解决这个问题,命令为0.0.0.0/1 和
子网创建单独的路由,其中也包括完整的 IPv4 地址空间。128.0.0.0/1
- 将网络接口配置为内部工作站子网:
# nmcli connection add type ethernet con-name Internal-Workstations ifname enp8s0 ipv4.method manual ipv4.addresses 10.0.0.1/24 ipv4.routes "10.0.0.0/24 src=192.0.2.1 table=5000" ipv4.routing-rules "priority 5 from 10.0.0.0/24 table 5000" connection.zone trusted
这个命令使用ipv4.routes
参数将静态路由添加到路由表中 ID 为 5000。10.0.0.0/24
子网的这一静态路由使用本地网络接口的 IP 地址到供应商 B(192.0.2.1)作为下一跃点
。另外,该命令使用ipv4.routing-rules
参数添加优先级为 5 的路由规则,该规则将10.0.0.0/24
子网的流量路由到表 5000。低的值具有更高的优先级。请注意,ipv4.routing-rules
参数中的语法与 ip route add 命令中的语法相同,但ipv4.routing-rules
始终需要指定优先级。 - 将网络接口配置为服务器子网:
# nmcli connection add type ethernet con-name Servers ifname enp9s0 ipv4.method manual ipv4.addresses 203.0.113.1/24 connection.zone trusted
验证步骤
- 在内部工作站子网的 RHEL 主机上:
- 安装 traceroute 软件包:
# yum install traceroute
- 使用
traceroute
工具显示到互联网主机的路由:# traceroute redhat.com traceroute to redhat.com (209.132.183.105), 30 hops max, 60 byte packets 1 10.0.0.1 (10.0.0.1) 0.337 ms 0.260 ms 0.223 ms 2 192.0.2.1 (192.0.2.1) 0.884 ms 1.066 ms 1.248 ms ...
命令的输出显示路由器通过192.0.2.1
(提供商 B 的网络)发送数据包。
- 在服务器子网的 RHEL 主机上:
- 安装 traceroute 软件包:
# yum install traceroute
- 使用
traceroute
工具显示到互联网主机的路由:# traceroute redhat.com traceroute to redhat.com (209.132.183.105), 30 hops max, 60 byte packets 1 203.0.113.1 (203.0.113.1) 2.179 ms 2.073 ms 1.944 ms 2 198.51.100.2 (198.51.100.2) 1.868 ms 1.798 ms 1.549 ms ...
命令的输出显示路由器通过198.51.100.2
发送数据包,即供应商 A 的网络。
故障排除步骤
- 显示规则列表:
# ip rule list 0: from all lookup local 5: from 10.0.0.0/24 lookup 5000 32766: from all lookup main 32767: from all lookup default
- 显示表 5000 中的路由:
# ip route list table 5000 0.0.0.0/1 via 192.0.2.2 dev enp1s0 proto static metric 100 10.0.0.0/24 dev enp8s0 proto static scope link src 192.0.2.1 metric 102 128.0.0.0/1 via 192.0.2.2 dev enp1s0 proto static metric 100
- 显示将哪些接口分配给哪些防火墙区:
# firewall-cmd --get-active-zones external interfaces: enp1s0 enp7s0 trusted interfaces: enp8s0 enp9s0
- 验证外部区是否启用了伪装 :
# firewall-cmd --info-zone=external external (active) target: default icmp-block-inversion: no interfaces: enp1s0 enp7s0 sources: services: ssh ports: protocols: masquerade: yes ...
其它资源
- 有关您可以在 nmcli connection add 命令中设置的 nm-settings(5) 参数的详情,请查看
ipv4.*
man page 中的 IPv4 设置 部分。 - 有关您可以在 nmcli connection add 命令中设置的 nm-settings(5) 参数的详情,请查看
connection.*
man page 中的 Connection 设置 部分。 - 有关使用 nmcli 管理 NetworkManager 连接的详情,请查看 nmcli(1) man page 中的 连接管理命令 部分。
部分 III. InfiniBand 和 RDMA 网络
第 13 章 配置 InfiniBand 和 RDMA 网络
13.1. 了解 InfiniBand 和 RDMA 技术
IP
数据传输中,计算机 A 上的应用程序 X 会将一些数据发送到计算机 B 上的应用程序 Y。 作为传输的一部分,机器 B 上的内核必须首先接收数据,解码数据包标头,确定数据属于应用程序 Y,唤醒应用程序 Y,等待应用程序 Y 执行读取系统调用到内核中,然后它必须手动将内核本身的内部内存空间中的数据复制到应用程序 Y 提供的缓冲区中。 此过程意味着大多数网络流量必须至少复制到系统的主内存总线上(当主机适配器使用 DMA 将数据放入内核提供的内存缓冲区时,以及内核将数据移动到应用程序内存缓冲时),这意味着计算机必须执行大量上下文切换以在内核上下文和应用程序 Y 上下文之间切换。当网络流量以非常高的速度流动并可能导致其他任务减慢时,这两种情况都会给系统带来非常高的 CPU 负载。
IP
通信,因为它们绕过内核在通信过程中的干预,并大大降低了处理网络通信通常需要的 CPU 开销。RDMA 协议允许机器中的主机适配器知道数据包何时来自网络,哪个应用程序应接收该数据包,并在应用程序的内存空间中移动。它不将数据包发送到内核,然后将其复制到用户应用的内存中,而是将数据包的内容直接置于应用的缓冲区中,而无需进一步干预。但是,无法使用大多数 IP
网络应用程序所基于的标准 Berkeley Sockets API 来实现,因此它必须提供自己的 API、InfiniBand Verbs API 和应用程序,然后才能直接使用 RDMA 技术。
- 互联网广域 RDMA 协议(iWARP)iWARP 是一种计算机网络协议,实施远程直接内存访问(RDMA),以通过 Internet 协议(IP)网络进行高效数据传输。
- RDMA over Converged Ethernet(RoCE)协议,之后通过以太网(IBoE)重命名为 InfiniBand。RoCE 是一种网络协议,允许通过以太网网络进行远程直接内存访问(RDMA)。
先决条件
IP
网络链路层作为其底层技术,因此它们的大部分配置实际上都包含在 第 3 章 配置 IP 网络 中。 在大多数情况下,一旦正确配置了 IP
网络功能,它们的 RDMA 功能都是自动的,只要安装了适用于硬件的正确驱动程序,就会显示。 每个红帽提供的内核都始终包括内核驱动程序,但是,如果在机器安装时未选择 InfiniBand 软件包组,则必须手动安装用户空间驱动程序。
root
用户身份输入:
~]# yum install libibverbs
/etc/modprobe.d/mlx4.conf
“以指示为以太网上未丢弃服务配置哪些数据包优先级的驱动程序”,这些卡将插入到并重新构建 initramfs
以包含修改的文件。较新的基于 mlx5 的卡会自动与交换机协商 PFC “设置,不需要任何模块选项告知它们未丢弃优先级或优先级”。
13.2. 使用 RoCE 传输数据
- RoCE v1
RoCE v1
协议是一个带有 ethertype0x8915
的以太网链路层协议,它允许同一以太网广播域中任何两个主机之间进行通信。使用 ConnectX-3 网络适配器时,RoCE v1 是 RDMA 连接管理器(RDMA_CM)的默认版本。- RoCE v2
RoCE v2
协议在 IPv4 或 IPv6 协议的 UDP 上存在。RoCE v2 保留 UDP 目的地端口号4791
。从 Red Hat Enterprise Linux 7.5 开始,RoCE v2 是 RDMA_CM 的默认版本,在使用 ConnectX-3 Pro、ConnectX-4、ConnectX-4 Lx 和 ConnectX-5 网络适配器时。硬件支持RoCE v1
和RoCE v2
。
先决条件
- 客户端和服务器都支持相同的 RoCE 模式。
- 客户端支持 RoCE v1 和服务器 RoCE v2。
- 连接成功:
- 如果客户端处于 RoCE v1 或 RoCE v2 模式,取决于使用的网卡和驱动程序,对应的服务器必须具有相同的版本才能创建连接。另外,如果客户端处于 RoCE v1,并且服务器采用 RoCE v2 模式,则连接会成功。
- 连接失败:
- 如果客户端在 RoCE v2 中,并且对应的服务器在 RoCE v1 中,则无法建立连接。在本例中,更新对应服务器的驱动程序或网络适配器,请参考 第 13.2 节 “使用 RoCE 传输数据”
客户端 | Server | 默认设置 |
---|---|---|
RoCE v1 | RoCE v1 | 连接 |
RoCE v1 | RoCE v2 | 连接 |
RoCE v2 | RoCE v2 | 连接 |
RoCE v2 | RoCE v1 | 无连接 |
过程 13.1. 当在 Roce v2 中运行的硬件 Already 时更改默认 RoCE 模式
- 进入
/sys/kernel/config/rdma_cm
目录,使其具有 RoCE 模式:~]# cd /sys/kernel/config/rdma_cm
- 输入带有以太网网络设备的ibstat 命令显示状态。例如,对于 mlx5_0:
~]$ ibstat mlx5_0 CA 'mlx5_0' CA type: MT4115 Number of ports: 1 Firmware version: 12.17.1010 Hardware version: 0 Node GUID: 0x248a0703004bf0a4 System image GUID: 0x248a0703004bf0a4 Port 1: State: Active Physical state: LinkUp Rate: 40 Base lid: 0 LMC: 0 SM lid: 0 Capability mask: 0x04010000 Port GUID: 0x268a07fffe4bf0a4 Link layer: Ethernet
- 为 mlx5_0 设备创建一个目录:
~]# mkdir mlx5_0
- 在
default_roce_mode
文件中以树格式显示 RoCE 模式:~]# cd mlx5_0
~]$ tree └── ports └── 1 ├── default_roce_mode └── default_roce_tos
~]$ cat /sys/kernel/config/rdma_cm/mlx5_0/ports/1/default_roce_mode RoCE v2
- 更改默认 RoCE 模式:
~]# echo "RoCE v1" > /sys/kernel/config/rdma_cm/mlx5_0/ports/1/default_roce_mode
- 查看更改:
~]$ cat /sys/kernel/config/rdma_cm/mlx5_0/ports/1/default_roce_mode RoCE v1
13.3. 配置 Soft-RoCE
先决条件
rxe_cfg
脚本。要查看 rxe_cfg
的选项,请输入 rxe_cfg 帮助。
过程 13.2. 配置 Soft-RoCE
- 以
root
用户身份,输入以下命令显示 RXE 的当前配置状态:~]# rxe_cfg rdma_rxe module not loaded Name Link Driver Speed NMTU IPv4_addr RDEV RMTU igb_1
yes
igb mlx4_1 no mlx4_en mlx4_2 no mlx4_en - 要载入 RXE 内核模块并启动 RXE,以
root
用户身份输入:~]# rxe_cfg start Name Link Driver Speed NMTU IPv4_addr RDEV RMTU igb_1
另外,要验证是否载入了 RXE 内核模块,请输入:yes
igb mlx4_1 no mlx4_en mlx4_2 no mlx4_en~]# lsmod |grep rdma_rxe rdma_rxe 111129 0 ip6_udp_tunnel 12755 1 rdma_rxe udp_tunnel 14423 1 rdma_rxe ib_core 236827 15 rdma_cm,ib_cm,iw_cm,rpcrdma,mlx4_ib,ib_srp,ib_ucm,ib_iser,ib_srpt,ib_umad,ib_uverbs,rdma_rxe,rdma_ucm,ib_ipoib,ib_isert
- 在通过以太网接口添加新 RXE 设备之前,应打开对应的接口并分配有有效的 IP 地址。添加新的 RXE 设备,如 igb_1 :
~]# rxe_cfg add igb_1
~]# rxe_cfg status Name Link Driver Speed NMTU IPv4_addr RDEV RMTU igb_1 yes igb rxe0 1024 (3) mlx4_1 no mlx4_en mlx4_2 no mlx4_en
RDEV 列中的 rxe0 表示为 igb_1 设备启用了 rxe。 - 要验证 RXE 设备的状态,请使用 ibv_devices 命令:
~]# ibv_devices device node GUID ------ ---------------- mlx4_0 0002c90300b3cff0 rxe0 a2369ffffe018294
或者,输入 aibstat 作为详细状态:~]# ibstat rxe0 CA 'rxe0' CA type: Number of ports: 1 Firmware version: Hardware version: Node GUID: 0xa2369ffffe018294 System image GUID: 0x0000000000000000 Port 1: State: Active Physical state: LinkUp Rate: 2.5 Base lid: 0 LMC: 0 SM lid: 0 Capability mask: 0x00890000 Port GUID: 0xa2369ffffe018294 Link layer: Ethernet
删除 RXE 设备
~]# rxe_cfg remove igb_1
验证 RXE 设备的连接性
例 13.1. 在服务器幻灯片中验证 RXE 设备的连接性
~]$ ibv_rc_pingpong -d rxe0 -g 0
local address: LID 0x0000, QPN 0x000012, PSN 0xe2965f, GID fe80::290:faff:fe29:486a
remote address: LID 0x0000, QPN 0x000011, PSN 0x4bf206, GID fe80::290:faff:fe29:470a
8192000 bytes in 0.05 seconds = 1244.06 Mbit/sec
1000 iters in 0.05 seconds = 52.68 usec/iter
例 13.2. 在客户端幻灯片中验证 RXE 设备的连接性
~]$ ibv_rc_pingpong -d rxe0 -g 0 172.31.40.4
local address: LID 0x0000, QPN 0x000011, PSN 0x4bf206, GID fe80::290:faff:fe29:470a
remote address: LID 0x0000, QPN 0x000012, PSN 0xe2965f, GID fe80::290:faff:fe29:486a
8192000 bytes in 0.05 seconds = 1245.72 Mbit/sec
1000 iters in 0.05 seconds = 52.61 usec/iter
13.5. 配置基本 RDMA 子系统
rdma
服务的启动是自动的。 当 RDMA 的硬件(无论是 InfiniBand 或 iWARP 或 RoCE/IBoE)被检测到时,udev 会指示 systemd
启动rdma
服务。
~]# systemctl status rdma
● rdma.service - Initialize the iWARP/InfiniBand/RDMA stack in the kernel
Loaded: loaded (/usr/lib/systemd/system/rdma.service; disabled; vendor preset: disabled)
Active: inactive (dead)
Docs: file:/etc/rdma/rdma.conf
用户不需要启用rdma
服务,但如果他们想随时强制使用该服务。要做到这一点,以 root 用户身份输入以下命令:
~]# systemctl enable rdma
13.5.1. 配置 rdma.conf 文件
Therdma
服务读取 /etc/rdma/rdma.conf
找出管理员默认载入的内核级和用户级 RDMA 协议。 用户应编辑此文件,以打开或关闭各种驱动程序。
IPoIB
- 这是一个IP
网络模拟层,允许IP
应用程序通过 InfiniBand 网络运行。SRP
- 这是 SCSI 请求协议。它允许计算机挂载通过SRP
协议导出的远程驱动器或驱动器阵列,就像是本地硬盘一样。SRPT
-这是SRP
协议的目标模式或服务器模式。 这会加载导出驱动器或驱动器阵列以便其他机器进行挂载所必需的内核支持,就像它是其计算机的本地计算机一样。在实际导出任何设备之前,需要进一步配置目标模式支持。如需更多信息,请参阅 targetd 和 targetcli 软件包中的文档。ISER
- 这是 Linux 内核通用 iSCSI 层的一个低级驱动程序,可为 iSCSI 设备通过 InfiniBand 网络进行传输。RDS
- 这是 Linux 内核中可靠的数据报服务。 它没有在 Red Hat Enterprise Linux 7 内核中启用,因此无法加载。
13.5.2. 70-persistent-ipoib.rules 的使用
/etc/udev.d/rules.d/70-persistent-ipoib.rules
。此 udev 规则文件用于将 IPoIB 设备从其默认名称(如 ib0
和 ib1
)重命名为更描述性的名称。用户必须编辑此文件,以更改其设备的命名方式。首先,找到要重命名设备的 GUID 地址:
~]$ ip link show ib0 8: ib0: >BROADCAST,MULTICAST,UP,LOWER_UP< mtu 65520 qdisc pfifo_fast state UP mode DEFAULT qlen 256 link/infiniband 80:00:02:00:fe:80:00:00:00:00:00:00:f4:52:14:03:00:7b:cb:a1 brd 00:ff:ff:ff:ff:12:40:1b:ff:ff:00:00:00:00:00:00:ff:ff:ff:ff
link/infiniband
后马上是 IPoIB 接口的 20 字节硬件地址。地址的最后 8 字节(标在上方标出)是生成新名称所需的一切。用户可以做出适合他们的任何命名方案。例如,如果 mlx4 设备连接到 aib 0 子网结构,则使用 device_ fabric
命名约定,如 mlx4
_ib
0。不推荐的唯一内容是使用标准名称,如 ib0 orib
1
,因为它们可能会与分配的内核自动名称冲突。接下来,在规则文件中添加一个条目。复制规则文件中的现有示例,将 ATTR{address} 条目中的 8 字节替换为要重命名的设备中突出显示的 8 字节,然后在 NAME
字段中输入要使用的新名称。
13.5.3. 为用户缓解 memlock 限制
root
之外的用户运行大型 RDMA 应用程序,可能需要增加非root
用户在系统中被允许的内存量。这可以通过在 /etc/security/limits.d/
目录中添加一个包含以下内容的文件来实现:
~]$ more /etc/security/limits.d/rdma.conf
# configuration for rdma tuning
* soft memlock unlimited
* hard memlock unlimited
# rdma tuning end
13.5.4. 为以太网操作配置 Mellanox 卡
/etc/rdma/mlx4.conf
文件,并按照该文件中的说明为 RoCE/IBoE 使用正确设置端口类型。在这种情况下,还需要重建 initramfs
,以确保将更新的端口设置复制到 initramfs
中。
mlx4_core 0000:05:00.0: Requested port type for port 1 is not supported on this HCA这是正常的,不会影响操作。负责设置端口类型的脚本不知道驱动程序何时在内部切换到请求的类型,从脚本发出端口 2 以切换至该交换机的时间,尝试将端口 1 设置为不同类型都会被拒绝。该脚本会重试,直到命令成功或超时传递之后,指示端口交换机永不完成。
13.5.5. 连接到远程 Linux SRP 目标
exampleib_qib
)可以具有不同的 GID 格式。ACL ID 还取决于您启动连接请求的方式。
连接到远程 Linux SRP 目标:高级别概述
- 准备目标侧:
- 创建存储后端。例如,获取 /dev/sdc1 分区:
/> /backstores/block create vol1 /dev/sdc1
- 创建 SRP 目标:
/> /srpt create 0xfe80000000000000001175000077dd7e
- 根据步骤中创建的后端创建一个 LUN:
/> /srpt/ib.fe80000000000000001175000077dd7e/luns create /backstores/block/vol1
- 为远程 SRP 客户端创建节点 ACL:
/> /srpt/ib.fe80000000000000001175000077dd7e/acls create 0x7edd770000751100001175000077d708
请注意,srp_daemon
的节点 ACL 不同。和ibsrpdm
- 为客户端发起与
srp_daemon 或
的 SRP 连接:ibsrpdm
[root@initiator]# srp_daemon -e -n -i qib0 -p 1 -R 60 &
[root@initiator]# ibsrpdm -c -d /dev/infiniband/umad0 > /sys/class/infiniband_srp/srp-qib0-1/add_target
- 可选。建议您使用不同的工具(如
lsscsi
或dmesg
)验证 SRP 连接。
过程 13.3. 使用 srp_daemon 或 ibsrpdm 连接到远程 Linux SRP 目标
- 对目标使用 ibstat 命令,以确定
状态
和端口GUID
值。HCA 必须处于Active
状态。ACL ID 基于端口 GUID
:[root@target]# ibstat CA 'qib0' CA type: InfiniPath_QLE7342 Number of ports: 1 Firmware version: Hardware version: 2 Node GUID: 0x001175000077dd7e System image GUID: 0x001175000077dd7e Port 1: State:
Active
Physical state: LinkUp Rate: 40 Base lid: 1 LMC: 0 SM lid: 1 Capability mask: 0x0769086a Port GUID:0x001175000077dd7e
Link layer: InfiniBand - 获取 SRP 目标 ID,它基于 HCA 端口的 GUID。请注意,您需要将专用磁盘分区作为 SRP 目标的后端,如
/dev/sdc1
。以下命令替换 fe80 的默认前缀,删除冒号,并在字符串的其余部分中添加新前缀:[root@target]# ibstatus | grep '<default-gid>' | sed -e 's/<default-gid>://' -e 's/://g' | grep 001175000077dd7e fe80000000000000001175000077dd7e
- 使用
targetcli
工具在块设备中创建 LUN vol1,创建一个 SRP 目标并导出 LUN:[root@target]# targetcli />
/backstores/block create vol1 /dev/sdc1
Created block storage object vol1 using /dev/sdc1. />/srpt create 0xfe80000000000000001175000077dd7e
Created target ib.fe80000000000000001175000077dd7e. />/srpt/ib.fe80000000000000001175000077dd7e/luns create /backstores/block/vol1
Created LUN 0. />ls /
o- / ............................................................................. [...] o- backstores .................................................................. [...] | o- block ...................................................... [Storage Objects: 1] | | o- vol1 ............................... [/dev/sdc1 (77.8GiB) write-thru activated] | o- fileio ..................................................... [Storage Objects: 0] | o- pscsi ...................................................... [Storage Objects: 0] | o- ramdisk .................................................... [Storage Objects: 0] o- iscsi ................................................................ [Targets: 0] o- loopback ............................................................. [Targets: 0] o- srpt ................................................................. [Targets: 1] o- ib.fe80000000000000001175000077dd7e ............................... [no-gen-acls] o- acls ................................................................ [ACLs: 0] o- luns ................................................................ [LUNs: 1] o- lun0 ............................................... [block/vol1 (/dev/sdc1)] /> - 在启动器中使用 ibstat 命令检查状态是否为
Active
,并确定端口 GUID
:[root@initiator]# ibstat CA 'qib0' CA type: InfiniPath_QLE7342 Number of ports: 1 Firmware version: Hardware version: 2 Node GUID: 0x001175000077d708 System image GUID: 0x001175000077d708 Port 1: State:
Active
Physical state: LinkUp Rate: 40 Base lid: 2 LMC: 0 SM lid: 1 Capability mask: 0x07690868 Port GUID:0x001175000077d708
Link layer: InfiniBand - 使用以下命令扫描,但不连接到远程 SRP 目标:目标 GUID 显示启动器已找到远程目标。ID 字符串显示远程目标是一个 Linux 软件目标(
ib_srpt.ko
)。[root@initiator]# srp_daemon -a -o IO Unit Info: port LID: 0001 port GID:
fe80000000000000001175000077dd7e
change ID: 0001 max controllers: 0x10 controller[ 1] GUID:001175000077dd7e
vendor ID: 000011 device ID: 007322 IO class : 0100 ID:Linux SRP target
service entries: 1 service[ 0]: 001175000077dd7e / SRP.T10:001175000077dd7e - 要验证 SRP 连接,请使用 lsscsi 命令列出 SCSI 设备,并在启动器连接到目标之前和之后比较 lsscsi 输出。
[root@initiator]# lsscsi [0:0:10:0] disk IBM-ESXS ST9146803SS B53C /dev/sda
- 要在没有为 initiator 端口配置有效 ACL 的情况下连接到远程目标(应该会失败),请对
srp_daemon
oribsrpdm
使用以下命令:[root@initiator]# srp_daemon -e -n -i qib0 -p 1 -R 60 & [1] 4184
[root@initiator]# ibsrpdm -c -d /dev/infiniband/umad0 > /sys/class/infiniband_srp/srp-qib0-1/add_target
- dmesg 的输出显示 SRP 连接操作失败的原因。在后续步骤中,使用目标端的 dmesg 命令使情况变得明确。
[root@initiator]# dmesg -c [ 1230.059652] scsi host5: ib_srp: REJ received [ 1230.059659] scsi host5: ib_srp: SRP LOGIN from
fe80:0000:0000:0000:0011:7500:0077:d708
to fe80:0000:0000:0000:0011:7500:0077:dd7e REJECTED, reason0x00010006
[ 1230.073792] scsi host5: ib_srp: Connection 0/2 failed [ 1230.078848] scsi host5: ib_srp: Sending CM DREQ failed - 由于 LOGIN 失败,lsscsi 命令的输出与上一步中的输出相同。
[root@initiator]# lsscsi [0:0:10:0] disk IBM-ESXS ST9146803SS B53C /dev/sda
- 在目标端使用 dmesg (
ib_srpt.ko
)提供了有关 LOGIN 失败的原因。此外,输出中还包含srp_daemon
提供的有效 ACL ID:0x7edd770000751100001175000077d708
。[root@target]# dmesg [ 1200.303001] ib_srpt Received SRP_LOGIN_REQ with i_port_id 0x7edd770000751100:0x1175000077d708, t_port_id 0x1175000077dd7e:0x1175000077dd7e and it_iu_len 260 on port 1 (guid=0xfe80000000000000:0x1175000077dd7e)
[ 1200.322207] ib_srpt Rejected login because no ACL has been configured yet for initiator 0x7edd770000751100001175000077d708.
- 使用
targetcli
工具添加有效的 ACL:[root@target]# targetcli targetcli shell version 2.1.fb41 Copyright 2011-2013 by Datera, Inc and others. For help on commands, type 'help'. /> /srpt/ib.fe80000000000000001175000077dd7e/acls create
0x7edd770000751100001175000077d708
Created Node ACL for ib.7edd770000751100001175000077d708 Created mapped LUN 0. - 验证 SRP LOGIN 操作:
- 等待 60 秒,以允许
srp_daemon
重新登录:[root@initiator]# sleep 60
- 验证 SRP LOGIN 操作:
[root@initiator]# lsscsi [0:0:10:0] disk IBM-ESXS ST9146803SS B53C /dev/sda
[7:0:0:0] disk LIO-ORG vol1 4.0 /dev/sdb
- 对于 SRP 目标发现的内核日志,请使用:
[root@initiator]# dmesg -c [ 1354.182072] scsi host7: SRP.T10:001175000077DD7E [ 1354.187258] scsi 7:0:0:0: Direct-Access LIO-ORG vol1 4.0 PQ: 0 ANSI: 5 [ 1354.208688] scsi 7:0:0:0: alua: supports implicit and explicit TPGS [ 1354.215698] scsi 7:0:0:0: alua: port group 00 rel port 01 [ 1354.221409] scsi 7:0:0:0: alua: port group 00 state A non-preferred supports TOlUSNA [ 1354.229147] scsi 7:0:0:0: alua: Attached [ 1354.233402] sd 7:0:0:0: Attached scsi generic sg1 type 0 [ 1354.233694] sd 7:0:0:0: [sdb] 163258368 512-byte logical blocks: (83.5 GB/77.8 GiB) [ 1354.235127] sd 7:0:0:0: [sdb] Write Protect is off [ 1354.235128] sd 7:0:0:0: [sdb] Mode Sense: 43 00 00 08 [ 1354.235550] sd 7:0:0:0: [sdb] Write cache: disabled, read cache: enabled, doesn't support DPO or FUA [ 1354.255491] sd 7:0:0:0: [sdb] Attached SCSI disk [ 1354.265233] scsi host7: ib_srp: new target: id_ext 001175000077dd7e ioc_guid 001175000077dd7e pkey ffff service_id 001175000077dd7e sgid fe80:0000:0000:0000:0011:7500:0077:d708 dgid fe80:0000:0000:0000:0011:7500:0077:dd7e xyx
13.6. 配置子网管理器
13.6.1. 确定需要
13.6.2. 配置 opensm 主配置文件
/etc/rdma/opensm.conf
中保留其主配置文件。用户可以随时编辑此文件,并且编辑操作会在升级过程中保留。 文件本身中有大量选项文档。但是,对于最常用的两个编辑,将 GUID 设置为绑定到 并且使用 来运行 PRIORITY,强烈建议不要编辑 opensm.conf
文件,而是编辑 /etc/sysconfig/opensm
。如果没有对基础 /etc/rdma/opensm.conf
文件的编辑,则每当 opensm 软件包升级时都会升级。随着新选项定期添加到此文件中,这有助于使当前配置保持最新。如果 opensm.conf
文件已被更改,然后在升级时,可能需要将新选项合并到编辑的文件中。
13.6.3. 配置 opensm 启动选项
/etc/sysconfig/opensm
文件中的选项控制子网管理器实际的启动方式,以及子网管理器的启动数量。例如,一个双端口 InfiniBand 卡(每个端口插入物理独立的网络中)将需要在每个端口上运行的子网管理器的副本。opensm 子网管理器将仅管理每个应用程序实例一个子网,并且必须为每个需要管理的子网启动一次。此外,如果有多个打开服务器,那么请在各服务器上设置优先级来控制要控制哪些端口以及控制器是控制器。
/etc/sysconfig/opensm
用来提供设置子网管理器优先级以及控制子网管理器绑定到哪个 GUID 的简单方法。/etc/sysconfig/opensm
文件中的选项有广泛的说明。用户只需要读取并遵循文件本身的指示,即可启用 openm 的故障转移和多结构操作。
13.6.4. 创建 P_Key 定义
默认情况下,openm.conf
会查找文件 /etc/rdma/partitions.conf
以获取要在结构上创建的分区列表。所有光纤必须包含 0x7fff
子网,并且所有交换机和所有主机必须属于该结构。除此之外,还可以创建任何其他分区,并且所有主机和所有交换机都不必是这些额外分区的成员。这样,管理员可以创建与 InfiniBand 光纤上以太网 VLAN 类似的子网。如果分区定义了给定速度(如 40 Gbps),并且网络上有一个主机无法执行 40 Gbps,那么该主机即使有权限加入分区也将无法加入分区,因为它不能满足速度要求,因此建议将分区速度设置为任何有权加入分区的主机速度最慢。如果某些主机子集需要更快的分区,请创建一个速度较高的不同分区。
0x7fff
分区速度降低 10 Gbps,以及速度为 40 Gbps 的 0x0002
分区:
~]$ more /etc/rdma/partitions.conf
# For reference:
# IPv4 IANA reserved multicast addresses:
# http://www.iana.org/assignments/multicast-addresses/multicast-addresses.txt
# IPv6 IANA reserved multicast addresses:
# http://www.iana.org/assignments/ipv6-multicast-addresses/ipv6-multicast-addresses.xml
#
# mtu =
# 1 = 256
# 2 = 512
# 3 = 1024
# 4 = 2048
# 5 = 4096
#
# rate =
# 2 = 2.5 GBit/s
# 3 = 10 GBit/s
# 4 = 30 GBit/s
# 5 = 5 GBit/s
# 6 = 20 GBit/s
# 7 = 40 GBit/s
# 8 = 60 GBit/s
# 9 = 80 GBit/s
# 10 = 120 GBit/s
Default=0x7fff, rate=3, mtu=4, scope=2, defmember=full:
ALL, ALL_SWITCHES=full;
Default=0x7fff, ipoib, rate=3, mtu=4, scope=2:
mgid=ff12:401b::ffff:ffff # IPv4 Broadcast address
mgid=ff12:401b::1 # IPv4 All Hosts group
mgid=ff12:401b::2 # IPv4 All Routers group
mgid=ff12:401b::16 # IPv4 IGMP group
mgid=ff12:401b::fb # IPv4 mDNS group
mgid=ff12:401b::fc # IPv4 Multicast Link Local Name Resolution group
mgid=ff12:401b::101 # IPv4 NTP group
mgid=ff12:401b::202 # IPv4 Sun RPC
mgid=ff12:601b::1 # IPv6 All Hosts group
mgid=ff12:601b::2 # IPv6 All Routers group
mgid=ff12:601b::16 # IPv6 MLDv2-capable Routers group
mgid=ff12:601b::fb # IPv6 mDNS group
mgid=ff12:601b::101 # IPv6 NTP group
mgid=ff12:601b::202 # IPv6 Sun RPC group
mgid=ff12:601b::1:3 # IPv6 Multicast Link Local Name Resolution group
ALL=full, ALL_SWITCHES=full;
ib0_2=0x0002, rate=7, mtu=4, scope=2, defmember=full:
ALL, ALL_SWITCHES=full;
ib0_2=0x0002, ipoib, rate=7, mtu=4, scope=2:
mgid=ff12:401b::ffff:ffff # IPv4 Broadcast address
mgid=ff12:401b::1 # IPv4 All Hosts group
mgid=ff12:401b::2 # IPv4 All Routers group
mgid=ff12:401b::16 # IPv4 IGMP group
mgid=ff12:401b::fb # IPv4 mDNS group
mgid=ff12:401b::fc # IPv4 Multicast Link Local Name Resolution group
mgid=ff12:401b::101 # IPv4 NTP group
mgid=ff12:401b::202 # IPv4 Sun RPC
mgid=ff12:601b::1 # IPv6 All Hosts group
mgid=ff12:601b::2 # IPv6 All Routers group
mgid=ff12:601b::16 # IPv6 MLDv2-capable Routers group
mgid=ff12:601b::fb # IPv6 mDNS group
mgid=ff12:601b::101 # IPv6 NTP group
mgid=ff12:601b::202 # IPv6 Sun RPC group
mgid=ff12:601b::1:3 # IPv6 Multicast Link Local Name Resolution group
ALL=full, ALL_SWITCHES=full;
13.6.5. 启用 opensm
root
用户身份运行以下命令:
~]# systemctl enable opensm
13.7. 测试早期 InfiniBand RDMA 操作
IP
的设备,因此用户应在配置了 IPoIB 并且设备具有 IP 地址后继续执行有关测试
RDMA 操作的部分。
启用rdma
服务并且启用了 opensm 服务(如果需要)并且安装了适用于特定硬件的适当用户空间库后,应该可以执行用户 spacerdma
操作。libibverbs-utils 软件包中的简单测试程序有助于确定 RDMA 操作是否正常工作。Theibv_devices 程序将显示系统中有哪些设备,sibv_devinfo 命令将提供关于每个设备的详细信息。例如:
~]$ ibv_devices device node GUID ------ ---------------- mlx4_0 0002c903003178f0 mlx4_1 f4521403007bcba0 ~]$ ibv_devinfo -d mlx4_1 hca_id: mlx4_1 transport: InfiniBand (0) fw_ver: 2.30.8000 node_guid: f452:1403:007b:cba0 sys_image_guid: f452:1403:007b:cba3 vendor_id: 0x02c9 vendor_part_id: 4099 hw_ver: 0x0 board_id: MT_1090120019 phys_port_cnt: 2 port: 1 state: PORT_ACTIVE (4) max_mtu: 4096 (5) active_mtu: 2048 (4) sm_lid: 2 port_lid: 2 port_lmc: 0x01 link_layer: InfiniBand port: 2 state: PORT_ACTIVE (4) max_mtu: 4096 (5) active_mtu: 4096 (5) sm_lid: 0 port_lid: 0 port_lmc: 0x00 link_layer: Ethernet ~]$ ibstat mlx4_1 CA 'mlx4_1' CA type: MT4099 Number of ports: 2 Firmware version: 2.30.8000 Hardware version: 0 Node GUID: 0xf4521403007bcba0 System image GUID: 0xf4521403007bcba3 Port 1: State: Active Physical state: LinkUp Rate: 56 Base lid: 2 LMC: 1 SM lid: 2 Capability mask: 0x0251486a Port GUID: 0xf4521403007bcba1 Link layer: InfiniBand Port 2: State: Active Physical state: LinkUp Rate: 40 Base lid: 0 LMC: 0 SM lid: 0 Capability mask: 0x04010000 Port GUID: 0xf65214fffe7bcba2 Link layer: Ethernet
port_lid
输出 of ibv_devinfo相同。
IP 地址来指定服务器
。
port_lid
(或基本 lid)和要测试的端口的端口 GUID(假设上述接口的端口 1,port _lid
/Base LID
为 2
,Port GUID 为 0xf4521403007bba1
)。然后,以所需选项开始 ,以专门绑定到要测试的卡和端口,并且指定应该以服务器模式运行。您可以通过传递 -?
或 --help
来查看可用的选项,但在本例中,我们需要 -S
或 --Server
选项,并需要 -C 或 --Ca 和 -
P
或 --
Port
绑定到特定卡和端口。注意:此实例中的端口不表示网络端口号,但在使用多端口卡时表示卡上的物理端口号。要使用多端口卡的第二个端口测试与 RDMA 结构的连接,需要告诉 ibping 绑定到卡 上
的端口 2。当使用单个端口卡或测试卡上的第一个端口时,不需要这个选项。例如:
~]$ ibping -S -C mlx4_1 -P 1
~]$ ibping -c 10000 -f -C mlx4_0 -P 1 -L 2
--- rdma-host.example.com.(none) (Lid 2) ibping statistics ---
10000 packets transmitted, 10000 received, 0% packet loss, time 816 ms
rtt min/avg/max = 0.032/0.081/0.446 ms
或者
~]$ ibping -c 10000 -f -C mlx4_0 -P 1 -G 0xf4521403007bcba1 \
--- rdma-host.example.com.(none) (Lid 2) ibping statistics ---
10000 packets transmitted, 10000 received, 0% packet loss, time 769 ms
rtt min/avg/max = 0.027/0.076/0.278 ms
此结果验证结束 RDMA 通信是否适用于用户空间应用程序。
~]$ ibv_devinfo
libibverbs: Warning: no userspace device-specific driver found for /sys/class/infiniband_verbs/uverbs0
No IB devices found
此错误表示未安装必要的用户空间库。管理员将需要安装第 第 13.4 节 “InfiniBand 和 RDMA 相关软件包” 节中列出的一个用户空间库(适合其硬件)。在个别情况下,当用户为驱动程序安装错误的 arch 类型或 libibverbs 时会出现这种情况。例如,如果 libibverbs 是 arch x86_64
,并且已安装 libmlx4,但类型为 i686
,则可能会造成这个错误。
13.8. 配置 IPoIB
13.8.1. 了解 IPoIB 的角色
IP
网络。InfiniBand 不是.IPoIB 的角色是在 InfiniBand RDMA 网络之上提供 IP
网络模拟层。这允许现有应用程序在不修改的情况下通过 InfiniBand 网络运行。但是,这些应用程序的性能要比编写应用程序原生使用 RDMA 通讯时要低得多。由于大多数 InfiniBand 网络都有某些应用程序必须能从网络获取所有性能,而其他一些应用程序如果表示不需要修改应用程序来使用 RDMA 通讯,就可以接受降低性能率的其他应用程序。
IP
网络,其 IPDMA 层顶端的 IP
网络,所以不需要 IPoIB。因此,内核将拒绝在 iWARP 或 RoCE/IBoE RDMA 设备之上创建任何 IPoIB 设备。
13.8.2. 了解 IPoIB 通信模式
IP
数据包之上添加一个 4 字节 IPoIB 标头。因此,IPoIB MTU 需要比 InfiniBand link-layer MTU 小 4 字节。因为 2048 是一个常见的 InfiniBand 链路层 MTU,数据报模式中常见的 IPoIB 设备 MTU 是 2044。
IP
数据包只具有 16 位大小字段的限制,因此限制为 65535
的最大字节数。允许的最大 MTU 实际上比这小,因为我们还必须考虑还必须符合该大小的各种 TCP/IP 标头。因此,连接模式中的 IPoIB MTU 被上限为 65520
,以确保有足够的空间用于所有需要的 TCP
标头。
13.8.3. 了解 IPoIB 硬件地址
0xfe:80:00:00:00:00:00:00:00
。该设备将使用默认子网前缀(0xfe80000000000000),直到它与子网管理器取得联系,此时它将重置子网前缀,使其与子网管理器已将其配置为匹配。最后 8 字节是 IPoIB 设备所附加的 InfiniBand 端口的 GUID 地址。因为前 4 字节和接下来 8 字节可能会随时变化,所以在为 IPoIB 接口指定硬件地址时,不会使用或匹配它们。第 13.5.2 节 “70-persistent-ipoib.rules 的使用” 部分解释了如何通过将 udev 规则文件中的 ATTR{address} 字段的前 12 字节离开 ATTR{address} 字段来生成地址,从而使设备匹配可靠。在配置 IPoIB 接口时,配置文件的 HWADDR 字段可以包含所有 20 字节,但实际只使用最后 8 字节来匹配并查找配置文件指定的硬件。但是,如果设备配置文件中 TYPE=InfiniBand 条目未正确拼写,如果up-ib 不是用于打开 IPoIB 接口的实际脚本,则系统将无法找到配置指定的硬件的错误将会发出。对于 IPoIB 接口,配置文件的 TYPE= 字段必须是 InfiniBand
或 infiniband
(条目区分大小写,但脚本将接受这两个特定拼写)。
13.8.4. 了解 InfiniBand P_Key 子网
P_Key
子网在逻辑上细分为虚拟子网。这与在以太网接口上使用 VLAN 非常相似。所有交换机和主机必须是默认 P_Key
子网的成员,但管理员可以创建额外的子网,并将这些子网的成员限制为 fabric 中的主机或交换机的子集。P_Key
子网必须由子网管理器定义,然后主机才能使用它。有关如何使用 opensm 子网管理器定义 P_Key
子网的信息,请参阅 第 13.6.4 节 “创建 P_Key 定义” 部分。对于 IPoIB 接口,一旦创建了 P_Key
子网,我们可以为这些 P_Key
子网创建额外的 IPoIB 配置文件。正如以太网设备上的 VLAN 接口一样,每个 IPoIB 接口的行为就像它位于与其他 IPoIB 接口完全不同的结构上一样,这些接口共享同一链路,但具有不同的 P_Key
值。
P_Key
接口的名称有特殊要求。所有 IPoIB P_Key
s 范围从 0x0000
到 0x7fff
,高位 0x8000
表示 P_Key
成员资格是完全成员资格,而不是部分成员身份。Linux 内核的 IPoIB 驱动程序只支持 P_Key
子网中的完全成员资格,因此对于 Linux 可以连接的任何子网而言,会始终设置 P_Key
编号的高位。这意味着,如果 Linux 计算机加入 P_Key 0x0002
,一旦加入,实际的 P_Key
编号将为 0x8002
,表示我们是 P_Key 0x0002
的所有成员。因此,当在 opensm partitions.conf
文件中创建 P_Key
定义时,如 第 13.6.4 节 “创建 P_Key 定义” 部分所述,需要指定不使用 0x8000
的 P_Key
值,但在 Linux 客户端上定义 P_Key
IPoIB 接口时,将 0x8000
值添加到基本 P_Key
值。
13.8.5. 使用文本用户界面 nmtui 配置 InfiniBand
~]$ nmtui
此时将显示文本用户界面。任何无效的命令都会打印用法消息。
图 13.1. NetworkManager Text 用户界面添加 InfiniBand 连接菜单
[D]
图 13.2. NetworkManager 文本用户界面配置 InfiniBand 连接菜单
[D]
13.8.6. 使用命令行工具 nmcli 配置 IPoIB
ib_ipoib
内核模块,然后重新载入它,用户可以强制重命名 IPoIB 接口而不重新启动:
~]$ rmmod ib_ipoib ~]$ modprobe ib_ipoib
例 13.3. 在两个单独的命令中创建和修改 IPoIB。
~]$ nmcli con add type infiniband con-name mlx4_ib0 ifname mlx4_ib0 transport-mode connected mtu 65520 Connection 'mlx4_ib0' (8029a0d7-8b05-49ff-a826-2a6d722025cc) successfully added. ~]$ nmcli con edit mlx4_ib0 ===| nmcli interactive connection editor |=== Editing existing 'infiniband' connection: 'mlx4_ib0' Type 'help' or '?' for available commands. Type 'describe [>setting<.>prop<]' for detailed property description. You may edit the following settings: connection, infiniband, ipv4, ipv6 nmcli> set infiniband.mac-address 80:00:02:00:fe:80:00:00:00:00:00:00:f4:52:14:03:00:7b:cb:a3 nmcli> save Connection 'mlx4_ib3' (8029a0d7-8b05-49ff-a826-2a6d722025cc) successfully updated. nmcli> quit
例 13.4. 通过一个命令创建和修改 IPoIB.
nmcli con add type infiniband con-name mlx4_ib0 ifname mlx4_ib0 transport-mode connected mtu 65520 infiniband.mac-address 80:00:02:00:fe:80:00:00:00:00:00:00:f4:52:14:03:00:7b:cb:a3
mlx4_ib0
的 IPoIB 接口,并设置为使用连接模式、最大连接模式 MTU、DHCP
(IPv 4
和 IPv6
)。如果将 IPoIB 接口用于集群流量和用于集群外通信的以太网接口,则可能需要在 IPoIB 接口上禁用默认路由和任何默认名称服务器。这可按如下方式完成:
~]$ nmcli con edit mlx4_ib0
===| nmcli interactive connection editor |===
Editing existing 'infiniband' connection: 'mlx4_ib0'
Type 'help' or '?' for available commands.
Type 'describe [>setting<.>prop<]' for detailed property description.
You may edit the following settings: connection, infiniband, ipv4, ipv6
nmcli> set ipv4.ignore-auto-dns yes
nmcli> set ipv4.ignore-auto-routes yes
nmcli> set ipv4.never-default true
nmcli> set ipv6.ignore-auto-dns yes
nmcli> set ipv6.ignore-auto-routes yes
nmcli> set ipv6.never-default true
nmcli> save
Connection 'mlx4_ib0' (8029a0d7-8b05-49ff-a826-2a6d722025cc) successfully updated.
nmcli> quit
P_Key
接口,请使用 nmcli 创建一个,如下所示:
~]$ nmcli con add type infiniband con-name mlx4_ib0.8002 ifname mlx4_ib0.8002 parent mlx4_ib0 p-key 0x8002 Connection 'mlx4_ib0.8002' (4a9f5509-7bd9-4e89-87e9-77751a1c54b4) successfully added. ~]$ nmcli con modify mlx4_ib0.8002 infiniband.mtu 65520 infiniband.transport-mode connected ipv4.ignore-auto-dns yes ipv4.ignore-auto-routes yes ipv4.never-default true ipv6.ignore-auto-dns yes ipv6.ignore-auto-routes yes ipv6.never-default true
13.8.7. 使用命令行配置 IPoIB
ib_ipoib
内核模块,然后重新载入它,用户可以强制重命名 IPoIB 接口而不重新启动:
~]$ rmmod ib_ipoib ~]$ modprobe ib_ipoib
ifcfg
文件,以控制设备。带有静态 IPv4
寻址的典型 IPoIB 配置文件如下:
~]$ more ifcfg-mlx4_ib0
DEVICE=mlx4_ib0
TYPE=InfiniBand
ONBOOT=yes
HWADDR=80:00:00:4c:fe:80:00:00:00:00:00:00:f4:52:14:03:00:7b:cb:a1
BOOTPROTO=none
IPADDR=172.31.0.254
PREFIX=24
NETWORK=172.31.0.0
BROADCAST=172.31.0.255
IPV4_FAILURE_FATAL=yes
IPV6INIT=no
MTU=65520
CONNECTED_MODE=yes
NAME=mlx4_ib0
DEVICE 字段必须与任何 udev 重命名规则中创建的自定义名称匹配。NAME 条目不需要与设备名称匹配。如果启动 GUI 连接编辑器,则 NAME 字段用于向用户显示此连接的名称。TYPE 字段必须是 InfiniBand,才能正确处理 InfiniBand 选项。CONNECTED_MODE 为 yes
或 no
,其中 yes
将使用连接模式,并且 no
将使用数据报模式进行通信(请参阅 第 13.8.2 节 “了解 IPoIB 通信模式”部分)。
P_Key
接口,这是典型的配置文件:
~]$ more ifcfg-mlx4_ib0.8002
DEVICE=mlx4_ib0.8002
PHYSDEV=mlx4_ib0
PKEY=yes
PKEY_ID=2
TYPE=InfiniBand
ONBOOT=yes
HWADDR=80:00:00:4c:fe:80:00:00:00:00:00:00:f4:52:14:03:00:7b:cb:a1
BOOTPROTO=none
IPADDR=172.31.2.254
PREFIX=24
NETWORK=172.31.2.0
BROADCAST=172.31.2.255
IPV4_FAILURE_FATAL=yes
IPV6INIT=no
MTU=65520
CONNECTED_MODE=yes
NAME=mlx4_ib0.8002
对于所有 P_Key
接口文件,PHYSDEV 指令是必需的,且必须是父设备的名称。PKEY 指令必须设置为 yes
,而 PKEY_ID
必须是接口的编号(添加有或不带 0x8000
个成员身份)。但是,设备名称必须是 PKEY_ID
的四位十六进制表示法和 0x8000
成员资格位(使用逻辑 OR 运算符): NAME=${PHYSDEV}.$((0x8000 | $PKEY_ID))
PKEY_ID
被视为十进制数字,转换为十六进制数,然后使用逻辑 OR 运算符与 0x8000
运算符合并,以达到该设备的正确名称,但用户可以通过将标准的 0x
前缀添加到该数字,以十六进制指定 PKEY_ID
。
13.8.8. 配置 IPoIB 后测试 RDMA 网络
IP 地址指定
RDMA 设备。由于使用 IP
地址和主机名指定机器具有无处不在的性质,因此大多数 RDMA 应用程序将此用作首选,或在某些情况下仅使用它来指定要连接的远程计算机或本地设备。
IP
网络测试工具并提供要测试的 IPoIB 设备的 IP 地址
。例如,IPoIB 设备的 IP 地址之间的
ping 命令现在应该可以正常工作。
IP
地址或主机名指定的,但测试应用程序可以通过不同的 RDMA 接口进行实际连接。这是因为从主机名或 IP 地址转换为
RDMA 地址的过程允许在两台机器之间使用有效的 RDMA 地址对。如果客户端可以通过多种方式连接到服务器,那么如果指定的路径出现问题,则程序可以选择使用其他路径。例如,如果每台机器上有两个端口连接到同一 InfiniBand 子网,并且每台机器上提供了第二个端口的 IP 地址
,则该程序可能会发现每台机器上的第一个端口是有效的连接方法并使用它们。在这种情况下,任何 perftest 程序的命令行选项都可以用来告诉他们要绑定的卡和端口,如 第 13.7 节 “测试早期 InfiniBand RDMA 操作” 中的同级操作一样,以确保测试在需要测试的特定端口上进行。对于 qperf,绑定到端口的方法略有不同。qperf 程序作为一台计算机上的服务器运行,侦听所有设备(包括非 RDMA 设备)。客户端可以使用服务器的任何有效 IP 地址或主机名连接到
qperf。 qperf 将首先尝试打开数据连接,并通过客户端命令行上给定的 IP
地址或主机名运行请求的测试,但是如果使用该地址出现问题,qperf 将回退到尝试在客户端和服务器之间的任何有效路径上运行测试。因此,要强制 qperf 通过特定链接进行测试,请将 -loc_id
和 -rem_id
选项用于 qperf 客户端,以强制测试在特定的链接上运行。
13.8.9. 使用 GUI 配置 IPoIB
过程 13.4. 使用 nm-connection-editor 添加新的 InfiniBand 连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 单击添加按钮。此时将显示 Choose a Connection Type 窗口。选择 InfiniBand 并点 Create。此时会出现 Editing InfiniBand 连接 1 窗口。
- 在 InfiniBand 标签页中,从您要用于 InfiniBand 连接的下拉菜单中选择传输模式。
- 输入 InfiniBand MAC 地址。
- 检查并确认设置,然后单击保存按钮。
- 使用 第 13.8.9.1 节 “配置 InfiniBand 选项卡” 编辑与 InfiniBand 相关的设置。
过程 13.5. 编辑现有的 InfiniBand 连接
- 在终端中输入 nm-connection-editor :
~]$ nm-connection-editor
- 选择您要编辑的连接并点击 Edit 按钮。
- 选择常规选项卡。
- 配置连接名称、自动连接行为和可用性设置。Editing 对话框中的五个设置对所有连接类型通用,请参阅 General 选项卡:
- 连接名称 - 输入您的网络连接描述性名称。此名称将用于在 Network 窗口的菜单中列出此连接。
- 当这个网络可用时自动连接到这个网络 - 如果您希望 NetworkManager 在可用时自动连接到这个连接,请选择这个框。如需更多信息,请参阅 “使用 control-center 编辑现有连接”一节。
- 所有用户可以连接到此网络 - 选择此框可创建系统上所有用户可用的连接。更改此设置可能需要 root 特权。详情请查看 第 3.4.5 节 “使用 GUI 管理系统范围以及专用连接配置集”。
- 使用这个连接时自动连接到 VPN - 如果您希望 NetworkManager 在有可用时自动连接到 VPN 连接,请选择这个框。从下拉菜单中选择 VPN。
- firewall Zone - 从下拉菜单中选择防火墙区域。有关防火墙区域的更多信息,请参阅Red Hat Enterprise Linux 7 安全指南。
- 通过引用 第 13.8.9.1 节 “配置 InfiniBand 选项卡” 来编辑特定于 InfiniBand 的设置。
保存您的新(或修改)连接并创建进一步配置
- 或者
13.8.9.1. 配置 InfiniBand 选项卡
- 传输模式
- 数据报或连接模式可从下拉列表中选择。选择您的 IPoIB 网络其余部分正在使用的相同模式。
- 设备 MAC 地址
- 如果已安装 InfiniBand 硬件,则会预先填充 InfiniBand 功能设备的 MAC 地址,用于 InfiniBand 网络流量。这个硬件地址字段会被预先填充。
- MTU
- (可选)为通过 InfiniBand 连接发送的数据包设置最大传输单元(MTU)大小。
13.8.10. 其它资源
安装的文档
/usr/share/doc/initscripts-版本/sysconfig.txt
- 描述配置文件及其指令.
在线文档
- https://www.kernel.org/doc/Documentation/infiniband/ipoib.txt
- IPoIB 驱动程序的描述。包括对相关 RFC 的引用.
部分 IV. 服务器
第 14 章 DHCP 服务器
DHCP
客户端连接到中央位置的 DHCP
服务器,后者返回该客户端的网络配置(包括 IP 地址
、网关和 DNS
服务器)。
14.1. 为什么使用 DHCP?
DHCP
对于自动配置客户端网络接口非常有用。在配置客户端系统时,您可以选择 DHCP
,而不是指定 IP 地址
、子网掩码、网关或 DNS
服务器。客户端从 DHCP
服务器检索此信息。如果您要更改大量系统的 IP 地址
,DHCP
也非常有用。您无需重新配置所有系统,只需在服务器上为新 IP 地址集编辑一个配置文件
。如果组织的 DNS
服务器有变化,则更改发生在 DHCP
服务器上,而不是在 DHCP
客户端上。当您重新启动网络或重新引导客户端时,更改将生效。
DHCP
服务器连接到网络,笔记本电脑和其他移动计算机用户可以将这些设备从办公室移到办公室。
14.2. 配置 DHCP 服务器
服务器
。以 root
用户身份安装软件包:
~]# yum install dhcp
/etc/dhcp/dhcpd.conf
,该文件只是一个空配置文件。以 root
身份运行以下命令:
~]# cat /etc/dhcp/dhcpd.conf
#
# DHCP Server Configuration file.
# see /usr/share/doc/dhcp*/dhcpd.conf.example
# see dhcpd.conf(5) man page
#
/usr/share/doc/dhcp-版本;/dhcpd.conf.example
中找到。您应该使用此文件来帮助您配置 /etc/dhcp/dhcpd.conf
,详情如下。
14.2.1. 配置文件
DHCP
服务器的第一步是创建 配置文件,该文件存储客户端的网络信息。使用此文件声明客户端系统的选项。
#
)开头的行被视为注释。
- 参数 - 说明如何执行任务,无论是执行任务,还是要将哪些网络配置选项发送到客户端。
- 声明 - 描述网络拓扑、描述客户端、为客户端提供地址,或者对一组声明应用一组参数。
DHCP
选项;而参数配置不是可选的值或控制 DHCP
服务器的行为方式。
{ }
)括起的部分之前声明的参数(包括选项)被视为全局参数。全局参数应用到它下面的所有部分。
DHCP
守护进程使用 systemctl restart dhcpd 命令重启为止。
DHCP
配置文件和每次重新启动服务,而是提供了一种交互式方式来连接、查询和更改 DHCP
服务器的配置。通过使用omshell,可在服务器运行期间进行所有更改。有关omshell的详情请参考 theomshell man page。