6.1 基础网络

FreeBSD 是理想的互联网或内网服务器操作系统,能在极高负载下提供稳健的网络服务,并高效使用内存以维持数千个并发用户进程的良好响应时间。

FreeBSD 网络配置涉及多个核心命令和配置文件:

  • ifconfig 命令用于配置网络接口参数;

  • route 命令用于手动操作网络路由表;

  • /etc/rc.conf 是系统启动配置的核心文件,网络接口的持久化配置均存储在此文件中;

  • /etc/resolv.conf 文件用于配置 DNS 解析器信息;

  • /etc/hosts 文件提供本地主机名到 IP 地址的静态映射。

网络模型基础

计算机网络是将地理位置不同、具有独立功能的多台计算机及其外部设备,通过通信线路连接起来的系统。在网络操作系统、网络管理软件及网络通信协议的管理和协调下,该网络实现资源共享和信息传递。

FreeBSD 网络子系统基于 TCP/IP 协议族实现,遵循互联网协议套件的分层架构。

TCP/IP 协议族采用四层模型组织网络功能:

  • 网络接口层(Link Layer):负责在物理网络介质上发送和接收数据帧,处理硬件地址(MAC 地址)解析。该层对应 FreeBSD 中的网络接口驱动程序和 ifconfig 命令管理的配置。以太网帧的发送和接收、ARP(Address Resolution Protocol)地址解析均在该层完成。

  • 互联网层(Internet Layer):负责数据包的路由和转发,核心协议为 IP(Internet Protocol)。该层处理逻辑寻址(IP 地址)、分片与重组、路由选择等功能。路由表管理和 route 命令操作属于该层。

  • 传输层(Transport Layer):提供端到端的通信服务,主要协议为 TCP(Transmission Control Protocol)和 UDP(User Datagram Protocol)。TCP 提供可靠的面向连接传输,UDP 提供无连接的不可靠传输。FreeBSD 实现了一种多 TCP 栈共存架构,允许系统同时加载多个 TCP 协议栈实现。

  • 应用层(Application Layer):包含多种面向用户的网络应用协议,如 HTTP、SSH、DNS、SMTP 等。FreeBSD 通过 Ports 和 pkg 提供了大量网络服务软件。

参考文献

  • Kurose J F, Ross K W. 计算机网络:自顶向下方法(原书第 8 版)[M]. 陈鸣,译. 北京:机械工业出版社,2022. ISBN 978-7-111-71236-7.

识别网络适配器

FreeBSD 支持多种有线和无线网络适配器。查看所用 FreeBSD 版本的硬件兼容性列表,确认网络适配器是否受支持。

识别网络适配器方法一

要获取系统使用的网络适配器,执行以下命令:

输出示例如下:

@ 符号前的文本是控制设备的驱动程序名称。在此示例中,分别是 em(4) 和 iwm(4)。

识别网络适配器方法二

使用 ifconfig 命令可查看系统中的网络接口列表及其状态。

示例输出:

lo0 是本地回环接口,用于本机内部通信,不属于物理网卡。若 ifconfig 输出中仅显示 lo0 接口,则表示系统未识别物理网卡,此时应检查网卡硬件连接和驱动加载状态。可通过 dmesg | grep ether 命令查看网卡驱动加载日志。

配置 IPv4

配置动态 IPv4 地址

如果网络中有 DHCP 服务器,可使用 DHCP 动态获取 IP 地址。FreeBSD 使用 dhclient(8) 作为 DHCP 客户端。dhclient(8) 可自动获取 IP 地址、子网掩码和默认路由器。

注意

dhclient(8) 不支持 DHCPv6(RFC 3315/RFC 8415),IPv6 动态地址需使用 rtsold(8)(SLAAC)或第三方 DHCPv6 客户端(如 dhcp6c)。

要使接口使用 DHCP,执行以下命令:

可以手动运行 dhclient(8):

dhclient(8) 也可在后台启动。后台运行可能影响依赖网络的程序,但多数情况下能加快启动速度。

要在后台执行 dhclient(8),执行以下命令:

然后重启网络接口:

配置静态 IPv4 地址

也可在命令行通过 ifconfig(8) 配置网络接口卡,但若不同时将这些配置添加到 /etc/rc.conf 文件,重启后配置将丢失。

可通过以下命令设置 IP 地址:

要使更改在重启后持久化,执行以下命令:

一次性设置默认路由:

永久性添加默认路由器:

将 DNS 服务器地址添加到 /etc/resolv.conf 文件:

然后重启网络接口和路由:

可使用 ping(8) 测试连接:

如能正常收到 ICMP 响应报文,表明网络已连通。

注意

Jail 内默认不允许使用 ping(需设置 sysctl allow.raw_sockets)。

IPv6 配置

IPv6 是 IP 协议的新版本,也称为 IPv4 的后继。IPv6 相对于 IPv4 提供了多项优势和新功能:

  • 其 128 位地址空间可容纳约 3.4×10^38 个地址,从而解决了 IPv4 地址短缺与耗尽问题。

  • 路由器仅在路由表中存储网络聚合地址,从而将路由表的平均空间减少到 8192 个条目。

  • 地址自动配置(RFC4862)。

  • 强制多播地址。

  • 内置 IPsec(IP 安全)。

  • 简化的头部结构。

  • 对移动 IP 的支持。

  • IPv6 到 IPv4 的过渡机制。

FreeBSD 包括 KAME 项目 IPv6 参考实现,并附带 IPv6 所需的全部组件。

IPv6 地址有三种不同类型:

  • 单播(Unicast):发送到单播地址的数据包到达属于该地址的接口。

  • 任播(Anycast):这些地址在语法上与单播地址无法区分,但它们指向一组接口。发往任播地址的数据包将到达最近的接口。

  • 多播(Multicast):这些地址标识一组接口。发往多播地址的数据包将到达属于多播组的所有接口。IPv4 广播地址(通常为 xxx.xxx.xxx.255)在 IPv6 中由多播地址表示。

读取 IPv6 地址时,规范形式表示为 x:x:x:x:x:x:x:x,其中每个 x 代表一个 16 位十六进制值。例如 FEBC:A574:382B:23C1:AA49:4592:4EFE:9982

通常,地址会有很长的全零子字符串。::(双冒号)可用于替换每个地址中的一个子字符串。此外,每个十六进制值最多可省略三个前导零。例如,fe80::1 对应规范形式 fe80:0000:0000:0000:0000:0000:0000:0001

一些 IPv6 地址是保留的:

IPv6 地址
描述
说明

::/128

未指定地址

等同于 IPv4 中的 0.0.0.0

::1/128

回环地址

等同于 IPv4 中的 127.0.0.1

::ffff:0.0.0.0/96

IPv4 映射的 IPv6 地址

低 32 位是 IPv4 地址

fe80::/10

链路本地单播

等同于 IPv4 中的 169.254.0.0/16

fc00::/7

唯一本地

仅在协作站点集合内可路由

ff00::/8

多播

2000::/3

全局单播

所有全局单播地址从此池分配

2001:db8::/32

文档用途

用于文档中的 IPv6 地址前缀

配置动态 IPv6 地址

要使用 SLAAC 动态配置接口的 IPv6 地址:

注意,启用 IPv6 数据包转发(即 ipv6_gateway_enable=YES)后,除非将 net.inet6.ip6.rfc6204w3 sysctl(8) 变量设置为 1,否则系统不会配置 SLAAC 地址。

配置静态 IPv6 地址

要将 FreeBSD 系统配置为具有静态 IPv6 地址的 IPv6 客户端,需要设置 IPv6 地址:

要分配默认路由器:

参考文献

  • Li Q, Jinmei T, Shima K. IPv6 详解:卷 1,核心协议实现[M]. 陈涓,赵振平,译. 北京:人民邮电出版社,2009:846. ISBN: 978-7-115-18950-9 (英文影印版本 ISBN: 978-7-115-19551-7). 详解 IPv6 核心协议实现,基于 FreeBSD KAME 项目代码分析。

  • Li Q, Jinmei T, Shima K. IPv6 详解:卷 2,高级协议实现[M]. 王嘉祯,等,译. 北京:人民邮电出版社,2009:869. ISBN: 978-7-115-20891-0 (英文影印版本 ISBN: 978-7-115-19519-7). 详解 IPv6 高级协议与扩展机制,包含移动 IPv6 等关键技术。

主机名

主机名代表主机在网络上的完全限定域名(FQDN,Fully Qualified Domain Name)。

检查当前主机名:

临时更改主机名:

更改主机名并使其在重启后持久化:

DNS 配置详解

可将 DNS 理解为电话簿,其中 IP 地址与主机名相互对应。除非 /etc/nsswitch.conf 文件中另有说明,FreeBSD 将首先查看 /etc/hosts 文件中的地址,然后查看 /etc/resolv.conf 文件中的 DNS 信息。

相关文件结构:

本地地址 hosts 文件

/etc/hosts 文件是一个简单的文本数据库,提供主机名到 IP 地址的映射。通过 LAN 连接的本地计算机条目可添加到此文件中,用于简单的命名目的,无须设置 DNS 服务器。此外,/etc/hosts 文件可用于提供 Internet 名称的本地记录,减少对外部 DNS 服务器的查询需求。

例如,在本地环境中有 www/gitlab-ce 的本地实例,可以将如下行添加到 /etc/hosts 文件:

配置 DNS 名称服务器

FreeBSD 系统访问 Internet 域名系统(DNS)的方式由 resolv.conf(5) 控制。/etc/resolv.conf 文件中最常见的条目是:

  • nameserver:解析器应查询的名称服务器的 IP 地址。服务器按列出的顺序查询,最多三个。

  • search:主机名查找的搜索列表。通常由本地主机名的域确定。

  • domain:本地域名。

典型的 /etc/resolv.conf 文件如下:

search 和 domain 选项只能使用其中一个。使用 DHCP 时,dhclient(8) 通常会用从 DHCP 服务器接收的信息重写 /etc/resolv.conf 文件。

手动编辑 /etc/resolv.conf 文件后,重启系统时该文件可能重置,因为动态主机配置协议(Dynamic Host Configuration Protocol,DHCP)客户端在获取网络配置时会通过 resolvconf 服务重写该文件。

若需使用手动配置的 DNS 服务器而不希望系统自动更新覆盖,可禁用 resolvconf 服务。编辑 /etc/resolvconf.conf 文件(如不存在则创建),写入 resolvconf=NO 一行,该配置将禁用系统对 DNS 配置文件的自动更新。

参考文献

网络故障排除

排除硬件和软件配置故障时,首先检查以下基本要素:

  • 电源连接是否正常?

  • 路由器是否正常工作?

  • 宽带或网络费用是否缴纳?

  • 是否是区域性大规模网络中断事件?

  • 计算机的时间是否正确?

  • 网线是否插好?

  • 网络服务是否正确配置?

  • 防火墙是否正确配置?

  • 网卡是否受 FreeBSD 支持?

如果网卡工作正常但性能不佳,可参阅 tuning(7)。同时检查网络配置,因为不正确的网络设置可能导致连接缓慢。

“No route to host”消息表示系统无法将数据包路由到目标主机。这通常是因为未指定默认路由或网线未插入。检查 netstat -rn 的输出,确保有到主机的有效路由。

“ping: sendto: Permission denied”错误消息通常由防火墙配置错误引起。如果在 FreeBSD 上启用了防火墙但未定义规则,默认策略是拒绝所有流量,甚至是 ping(8)。

附录:网络配置 rc.conf 示例

注意

修改 /etc/rc.conf 文件后,需重启系统或运行命令 /etc/rc.d/netif restart 来应用网络更改。

① 在 /etc/rc.conf 文件中,如果需要一次性写入多个配置项,只能使用 ABC_XYZ="xxx yyy ccc ddd" 这种格式。

如果在 /etc/rc.conf 文件中写成以下形式:

这种形式下,后续的 ABC_XYZ 配置行会覆盖前一行,因此只有最后一行会生效。

查看网卡速率

如需实时监控网络接口的流量统计信息,可使用 systat 工具的网络接口视图。该命令以指定的刷新间隔显示各网络接口的接收和发送流量数据:

其中 -if 参数指定显示网络接口信息,数字 2 表示刷新间隔为 2 秒。

查看 FreeBSD 下载流量(bwm-ng)

如需查看更详细的网络流量统计,可安装 bwm-ng 工具,该工具提供多种流量显示格式和交互功能:

按字母 d 可切换流量显示格式,按 h 可查阅更多使用方法。

课后习题

  1. 在 FreeBSD 系统上配置双静态 IP 地址,分别设置不同的 DNS 服务器,使用 dig 命令验证每个 DNS 服务器的解析行为,分析 /etc/resolv.conf 中多 DNS 服务器条目的查询顺序与容错机制。

  2. 修改网络接口的 MTU(Maximum Transmission Unit)值为 9000(巨型帧),使用 ping 测试连通性,记录 MTU 变化对大包传输的影响,分析巨型帧在局域网与广域网中的适用场景。

  3. 禁用 resolvconf 服务,手动修改 /etc/resolv.conf 文件并重启网络服务,验证配置是否持久化,分析 resolvconf 对 DNS 配置动态管理的机制。

最后更新于