FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 从入门到追忆
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章
  • 书籍
  • FreeBSD 中文手册
  • 编辑日志
  • 译者说明
  • FreeBSD 中文手册
  • 概述
  • 前言
    • 致读者
    • 第四版
    • 第三版
    • 第二版(2004)
    • 第一版(2001)
    • 本书的组织结构
    • 本书中使用的一些约定
    • 致谢
  • 第一部分:快速开始
  • 第1章 简介
    • 1.1.概述
    • 1.2.欢迎来到 FreeBSD!
    • 1.3.关于 FreeBSD 项目
  • 第2章 安装 FreeBSD
    • 2.1.概述
    • 2.2.最低硬件要求
    • 2.3.安装前的准备工作
    • 2.4.开始安装
    • 2.5.使用 bsdinstall
    • 2.6.分配磁盘空间
    • 2.7.获取安装文件
    • 2.8.账户、时区、服务和安全
    • 2.9.故障排除
    • 2.10.使用 Live CD
  • 第3章 FreeBSD 基础
    • 3.1.概述
    • 3.2.虚拟控制台和终端
    • 3.3.用户和基本账户管理
    • 3.4.权限
    • 3.5.目录结构
    • 3.6.磁盘结构
    • 3.7.文件系统的挂载与卸载
    • 3.8.进程和守护进程
    • 3.9.Shell
    • 3.10.文本编辑器
    • 3.11.设备和设备节点
    • 3.12.手册页
  • 第4章 安装应用程序:软件包和 Ports
    • 4.1.概述
    • 4.2.软件安装的概述
    • 4.3.寻找所需的应用程序
    • 4.4.使用 pkg 管理二进制包
    • 4.5.使用 Ports
    • 4.6.使用 Poudriere 构建软件包
    • 4.7.安装后的注意事项
    • 4.8.如何处理损坏的 port
  • 第5章 X Window 系统
    • 5.1.概述
    • 5.2.安装 Xorg
    • 5.3.显卡驱动
    • 5.4.Xorg 配置
    • 5.5.在 X11 中使用字体
  • 第6章 FreeBSD 中的 Wayland
    • 6.1.简介
    • 6.2.Wayland 概述
    • 6.3.Wayfire 混成器
    • 6.4.Hikari 混成器
    • 6.5.Sway 混成器
    • 6.6.使用 Xwayland
    • 6.7.使用 VNC 进行远程连接
    • 6.8.Wayland 登录管理器
    • 6.9.实用工具
  • 第7章 网络
    • 7.1.概述
    • 7.2.设置网络
    • 7.3.有线网络
    • 7.4.无线网络
    • 7.5.主机名
    • 7.6.DNS
    • 7.7.故障排除
  • 第二部分:常见任务
  • 第8章 桌面环境
    • 8.1.概述
    • 8.2.桌面环境
    • 8.3.浏览器
    • 8.4.开发工具
    • 8.5.桌面办公应用
    • 8.6.文档阅读器
    • 8.7.财务
  • 第9章 多媒体
    • 9.1.概述
    • 9.2.设置声卡
    • 9.3.音频播放器
    • 9.4.视频播放器
    • 9.5.视频会议
    • 9.6.图像扫描仪
  • 第10章 配置 FreeBSD 内核
    • 10.1.概述
    • 10.2.为什么要构建定制内核
    • 10.3.浏览系统硬件
    • 10.4.配置文件
    • 10.5.构建并安装定制内核
    • 10.6.如果发生了错误
  • 第11章 打印
    • 11.1.快速入门
    • 11.2.连接打印机
    • 11.3.常见的页面描述语言(PDL)
    • 11.4.直接打印
    • 11.5.LPD(行式打印机程序)
    • 11.6.其他打印系统
  • 第12章 Linux 二进制兼容层
    • 12.1.概述
    • 12.2.配置 Linux 二进制兼容层
    • 12.3.Linux 用户空间
    • 12.4.高级主题
  • 第13章 WINE
    • 13.1.概述
    • 13.2.WINE 概述和概念
    • 13.3.在 FreeBSD 上安装 WINE
    • 13.4.在 FreeBSD 上运行第一个 WINE 程序
    • 13.5.配置 WINE 安装程序
    • 13.6.WINE 图形化用户管理界面
    • 13.7.多用户 FreeBSD 与 WINE
    • 13.8.FreeBSD 上的 WINE 常见问题
  • 第三部分:系统管理
  • 第14章 配置与优化
    • 14.1.概述
    • 14.2.配置文件
    • 14.3.管理 FreeBSD 中的服务
    • 14.4.Cron 和 Periodic
    • 14.5.配置系统日志
    • 14.6.电源和资源管理
    • 14.7.添加交换空间
  • 第15章 FreeBSD 的引导过程
    • 15.1.概述
    • 15.2.FreeBSD 的引导过程
    • 15.3.Device Hints
    • 15.4.关机流程
  • 第16章 安全
    • 16.1.概述
    • 16.2.简介
    • 16.3.账户安全
    • 16.4.入侵检测系统(IDS)
    • 16.5.安全等级
    • 16.6.文件标志位
    • 16.7.OpenSSH
    • 16.8.OpenSSL
    • 16.9.Kerberos
    • 16.10.TCP 封装器(TCP Wrapper)
    • 16.11.访问控制列表(ACL)
    • 16.12.Capsicum
    • 16.13.进程记账
    • 16.14.资源限制
    • 16.15.监控第三方安全问题
    • 16.16.FreeBSD 安全公告
  • 第17章 jail 与容器
    • 17.1.概述
    • 17.2.jail 的类型
    • 17.3.主机配置
    • 17.4.传统 jail(厚 jail)
    • 17.5.瘦 jail
    • 17.6.管理 jail
    • 17.7.更新 jail
    • 17.8.jail 资源限制
    • 17.9.jail 管理器与容器
  • 第18章 强制访问控制
    • 18.1.概述
    • 18.2.关键术语
    • 18.3.了解 MAC 标签
    • 18.4.规划安全配置
    • 18.5.可用的 MAC 策略
    • 18.6.用户锁定
    • 18.7.MAC Jail 中的 Nagios
    • 18.8.MAC 框架的故障排除
  • 第19章 安全事件审计
    • 19.1.概述
    • 19.2.关键术语
    • 19.3.审计配置
    • 19.4.使用审计跟踪
  • 第20章 存储
    • 20.1.概述
    • 20.2.添加磁盘
    • 20.3.调整和增加磁盘大小
    • 20.4.USB 存储设备
    • 20.5.创建和使用 CD
    • 20.6.创建和使用 DVD
    • 20.7.创建和使用软盘
    • 20.8.备份的基础知识
    • 20.9.内存盘
    • 20.10.文件系统快照
    • 20.11.磁盘配额
    • 20.12.加密磁盘分区
    • 20.13.加密交换分区
    • 20.14.高可用性存储(HAST)
  • 第21章 GEOM: 模块化磁盘转换框架
    • 21.1.概述
    • 21.2.RAID0——条带
    • 21.3.RAID1——镜像
    • 21.4.RAID3——带有专用奇偶校验的字节级条带
    • 21.5.软件 RAID 设备
    • 21.6.GEOM Gate 网络设备
    • 21.7.为磁盘设备添加卷标
    • 21.8.通过 GEOM 实现 UFS 日志
  • 第22章 Z 文件系统(ZFS)
    • 22.1.是什么使 ZFS 与众不同
    • 22.2.快速入门指南
    • 22.3.zpool 管理
    • 22.4.zfs 管理
    • 22.5.委托管理
    • 22.6.高级主题
    • 22.7.更多资源
    • 22.8.ZFS 特性和术语
  • 第23章 其他文件系统
    • 23.1.概述
    • 23.2.Linux® 文件系统
    • 23.3.Windows® 文件系统
    • 23.4.MacOS® 文件系统
  • 第24章 虚拟化
    • 24.1.概述
    • 24.2.使用 macOS® 上的 Parallels Desktop 安装 FreeBSD
    • 24.3.使用 macOS® 上的 VMware Fusion 安装 FreeBSD
    • 24.4.使用 VirtualBox™ 安装 FreeBSD
    • 24.5.在 FreeBSD 上安装 VirtualBox™
    • 24.6.使用 FreeBSD 上的 QEMU 虚拟化
    • 24.7.使用 FreeBSD 上的 bhyve 虚拟机
    • 24.8.基于 FreeBSD 的 Xen™ 虚拟机
  • 第25章 本地化——i18n/L10n 的使用和设置
    • 25.1.概述
    • 25.2.使用本地化
    • 25.3.寻找 i18n 应用程序
    • 25.4.特定语言的区域配置
  • 第26章 FreeBSD 更新与升级
    • 26.1.概述
    • 26.2.更新 FreeBSD
    • 26.3.更新 Bootcode
    • 26.4.更新文档
    • 26.5.追踪开发分支
    • 26.6.从源代码更新 FreeBSD
    • 26.7.多台机器的追踪
    • 26.8.在非 FreeBSD 主机上进行构建
  • 第27章 DTrace
    • 27.1.概述
    • 27.2.实现上的差异
    • 27.3.开启 DTrace 支持
    • 27.4.启用内核外部模块 DTrace
    • 27.5.使用 DTrace
  • 第28章 USB 设备模式/USB OTG
    • 28.1.概述
    • 28.2.USB 虚拟串行端口
    • 28.3.USB 设备模式网络接口
    • 28.4.USB 虚拟存储设备
  • 第四部分:网络通讯
  • 第29章 串行通信
    • 29.1.概述
    • 29.2.串行术语和硬件
    • 29.3.终端
    • 29.4.拨入服务
    • 29.5.拨出服务
    • 29.6.设置串行控制台
  • 第30章 PPP
    • 30.1.概述
    • 30.2.配置 PPP
    • 30.3.PPP 连接的故障排除
    • 30.4.使用以太网 PPP(PPPoE)
    • 30.5.使用 ATM 上的 PPP (PPPoA)
  • 第31章 电子邮件
    • 31.1.概述
    • 31.2.邮件组件
    • 31.3.DragonFly 邮件代理(DMA)
    • 31.4.Sendmail
    • 31.5.修改邮件传输代理
    • 31.6.邮件用户代理
    • 31.7.高级主题
  • 第32章 网络服务器
    • 32.1.概述
    • 32.2.inetd 超级服务器
    • 32.3.网络文件系统(NFS)
    • 32.4.网络信息系统(NIS)
    • 32.5.轻型目录访问协议(LDAP)
    • 32.6.动态主机设置协议(DHCP)
    • 32.7.域名系统(DNS)
    • 32.8.零配置网络(mDNS/DNS-SD)
    • 32.9.Apache HTTP 服务器
    • 32.10.文件传输协议(FTP)
    • 32.11.用于 Microsoft® Windows® 客户端的文件和打印服务(Samba)
    • 32.12.用 NTP 进行时钟同步
    • 32.13.iSCSI target 和 initiator 的配置
  • 第33章 防火墙
    • 33.1.概述
    • 33.2.防火墙的概念
    • 33.3.PF
    • 33.4.IPFW
    • 33.5.IPFILTER(IPF)
    • 33.6.Blacklistd
  • 第34章 高级网络
    • 34.1.概述
    • 34.2.网关和路由
    • 34.3.虚拟主机
    • 34.4.无线高级身份验证
    • 34.5.无线自组织(Ad-hoc)模式
    • 34.6.USB 网络共享
    • 34.7.蓝牙
    • 34.8.桥接
    • 34.9.链路聚合与故障转移
    • 34.10.使用 PXE 进行无盘操作
    • 34.11.共用地址冗余协议(CARP)
    • 34.12.VLAN
  • 第五部分:附录
  • 附录 A.获取 FreeBSD
    • A.1.镜像站
    • A.2.使用 Git
    • A.3.使用 Subversion
    • A.4.光盘
  • 附录 B.书目
    • B.1.FreeBSD 相关书籍
    • B.2.安全性参考文献
    • B.3.UNIX 历史
    • B.4.期刊与杂志
  • 附录 C.网络资源
    • C.1.网站
    • C.2.邮件列表
    • C.3.Usenet 新闻组
  • 附录 D.OpenPGP 密钥
    • D.1.官方成员
  • 术语表
  • 后记
由 GitBook 提供支持
在本页
  • 34.2.1. 路由基础
  • 34.2.2. 配置带静态路由的路由器
  • 34.2.3. 故障排除
  • 34.2.4. 多播考虑事项
在GitHub上编辑
导出为 PDF
  1. 第34章 高级网络

34.2.网关和路由

上一页34.1.概述下一页34.3.虚拟主机

最后更新于6天前

LogoLogo

FreeBSD 中文社区(CFC) 2025

路由 是使系统能够找到通往另一个系统的网络路径的机制。路由 是一对定义的地址,分别表示“目标”和“网关”。路由表明,当尝试连接到指定的目标时,应该通过指定的网关发送数据包。有三种目标类型:单个主机、子网和“默认”。“默认路由”在没有其他路由适用时使用。网关也有三种类型:单个主机、接口(也叫做链路)和以太网硬件(MAC)地址。已知的路由会存储在路由表中。

本节提供了路由基础的概述。然后展示了如何将 FreeBSD 系统配置为路由器,并提供了一些故障排除技巧。

34.2.1. 路由基础

要查看 FreeBSD 系统的路由表,可以使用 :

% netstat -r
Routing tables

Internet:
Destination      Gateway            Flags     Refs     Use     Netif Expire
default          outside-gw         UGS        37      418       em0
localhost        localhost          UH          0      181       lo0
test0            0:e0:b5:36:cf:4f   UHLW        5    63288       re0     77
10.20.30.255     link#1             UHLW        1     2421
example.com      link#1             UC          0        0
host1            0:e0:a8:37:8:1e    UHLW        3     4601       lo0
host2            0:e0:a8:37:8:1e    UHLW        0        5       lo0 =>
host2.example.com link#1            UC          0        0
224              link#1             UC          0        0

这个例子中的条目如下:

default 路由表中的第一个条目指定了 default 路由。当本地系统需要连接到远程主机时,它会检查路由表以确定是否有已知的路径。如果远程主机匹配表中的某个条目,系统将检查是否可以通过该条目中指定的接口连接。

如果目标不匹配任何条目,或者所有已知路径失败,系统将使用默认路由的条目。对于本地局域网上的主机,默认路由中的 Gateway 字段设置为具有直接互联网连接的系统。在读取此条目时,确保 Flags 列指示网关是可用的(UG)。

对于作为外部世界网关的机器,默认路由将是连接到互联网服务提供商(ISP)的网关机器。

localhost 第二个路由是 localhost 路由。Netif 列中为 localhost 指定的接口是 lo0,也称为回环设备。这表明所有发送到此目标的流量应保持在内部,而不是通过网络发送。

MAC 地址 以 0:e0: 开头的地址是 MAC 地址。FreeBSD 会自动识别本地以太网中的任何主机(例如示例中的 test0),并为该主机在以太网接口 re0 上添加一条路由。这种类型的路由有一个超时,如 Expire 列所示,如果主机在特定时间内没有响应,该路由将自动删除。这些主机是通过路由信息协议(RIP)识别的,RIP 根据最短路径确定到本地主机的路由。

子网 FreeBSD 会自动为本地子网添加子网路由。在这个例子中,10.20.30.255 是 10.20.30 子网的广播地址,example.com 是与该子网关联的域名。link#1 表示机器的第一个以太网卡。

主机host1 行通过以太网地址引用主机。由于它是发送主机,FreeBSD 知道要使用回环接口 (lo0),而不是以太网接口。

224 最后一行(目标子网 224)处理多播。

表 1. 常见的路由表标志

标志
目的

U

路由是活动的(启用)。

H

路由目标是单个主机。

G

将此目的地的任何流量转发到此网关,由网关决定如何进一步转发。

S

该路由是静态配置的。

C

基于此路由克隆一个新路由,用于机器的连接。此类路由通常用于本地网络。

W

该路由是根据本地网络(克隆)路由自动配置的。

L

路由涉及到以太网(链路)硬件的引用。

在 FreeBSD 系统中,可以通过在 /etc/rc.conf 中指定默认网关的 IP 地址来定义默认路由:

defaultrouter="10.20.30.1"

也可以使用 route 手动添加路由:

# route add default 10.20.30.1

34.2.2. 配置带静态路由的路由器

如果 FreeBSD 系统是双网卡系统,它可以配置为网络的默认网关或路由器。双网卡系统是指至少连接到两个不同网络的主机。通常,每个网络连接到一个独立的网络接口,尽管可以使用 IP 别名将多个地址绑定到一个物理接口,并使每个地址处于不同的子网。

为了让系统在接口之间转发数据包,FreeBSD 必须被配置为路由器。互联网标准和良好的工程实践不允许 FreeBSD 项目默认启用此功能,但可以通过在 /etc/rc.conf 中添加以下行来配置在启动时启用此功能:

gateway_enable="YES"          # 如果此主机是网关,则设置为 YES

路由器的路由表需要添加额外的路由,以便它知道如何到达其他网络。路由可以通过静态路由手动添加,也可以通过路由协议自动学习。静态路由适用于小型网络,本节将介绍如何为小型网络添加静态路由条目。

注意

考虑以下网络配置:

在此示例中,RouterA 是一台 FreeBSD 机器,充当通向外部互联网的路由器。它的默认路由设置为 10.0.0.1,允许它与外部世界连接。RouterB 已配置使用 192.168.1.1 作为其默认网关。

在添加任何静态路由之前,RouterA 的路由表如下所示:

% netstat -nr
Routing tables

Internet:
Destination        Gateway            Flags    Refs      Use  Netif  Expire
default            10.0.0.1           UGS         0    49378    xl0
127.0.0.1          127.0.0.1          UH          0        6    lo0
10.0.0.0/24        link#1             UC          0        0    xl0
192.168.1.0/24     link#2             UC          0        0    xl1

当前的路由表中,RouterA 没有到 192.168.2.0/24 网络的路由。以下命令将 Internal Net 2 网络添加到 RouterA 的路由表,并使用 192.168.1.2 作为下一跳:

# route add -net 192.168.2.0/24 192.168.1.2

现在,RouterA 可以访问 192.168.2.0/24 网络上的任何主机。但是,如果 FreeBSD 系统重新启动,路由信息将不会保留。如果需要使静态路由持久化,可以将其添加到 /etc/rc.conf 中:

# 将 Internal Net 2 添加为持久静态路由
static_routes="internalnet2"
route_internalnet2="-net 192.168.2.0/24 192.168.1.2"

static_routes 配置变量是一个由空格分隔的字符串列表,每个字符串引用一个路由名称。变量 route_internalnet2 包含该路由名称的静态路由。

使用多个字符串在 static_routes 中创建多个静态路由。以下示例显示了如何为 192.168.0.0/24 和 192.168.1.0/24 网络添加静态路由:

static_routes="net1 net2"
route_net1="-net 192.168.0.0/24 192.168.0.1"
route_net2="-net 192.168.1.0/24 192.168.1.1"

34.2.3. 故障排除

当一个地址空间被分配给一个网络时,服务提供商会配置他们的路由表,以确保所有流量都被发送到该站点的链接。但是,外部站点如何知道将其数据包发送到网络的 ISP 呢?

有一个系统跟踪所有分配的地址空间,并定义它们与互联网主干网(或承载互联网流量的主干线路)连接的节点。每台主干机器都保存一份主路由表,该表将特定网络的流量指向一个特定的主干承运商,从那里通过一系列服务提供商直到到达特定网络。

服务提供商的任务是向主干站点通告他们是连接点,因此也是流量的进入路径。这个过程被称为路由传播。

有时,路由传播会出现问题,导致某些站点无法连接。最有用的命令之一用于查找路由问题的断点是 traceroute,尤其是在 ping 失败时非常有用。

34.2.4. 多播考虑事项

FreeBSD 本身支持多播应用和多播路由。多播应用在 FreeBSD 上运行时无需进行特殊配置。要支持多播路由,必须将以下选项编译到自定义内核中:

options MROUTING

注意

本地网络主机和本地子网的路由是由一个名为 的守护进程自动配置的。如果它未运行,则只有管理员静态定义的路由存在。

两条 host2 行代表使用 创建的别名。lo0 接口后的 ⇒ 符号表示除了回环地址外,还设置了一个别名。此类路由仅出现在支持别名的主机上,本地网络上的所有其他主机将对这些路由显示 link#1 行。

可以在 Flags 列中查看每个路由的各种属性。 总结了这些标志及其含义。

请注意,手动添加的路由在重启后不会保留。有关手动操作网络路由表的更多信息,请参阅 。

要立即启用路由,请将 变量 net.inet.ip.forwarding 设置为 1。要停止路由,请将此变量重置为 0。

对于大型网络,静态路由很快变得不可扩展。FreeBSD 提供了标准的 BSD 路由守护进程 ,它提供了 RIP 协议(版本 1 和 2)和 IRDP 协议的支持。通过安装包或 Port ,可以支持 BGP 和 OSPF 路由协议。

静态路由

使用 traceroute 时,需要提供远程主机的地址。输出将显示路径上的网关主机,最终要么到达目标主机,要么因连接问题而终止。有关更多信息,请参阅 。

多播路由守护进程 mrouted 可以通过 软件包和 Ports 进行安装。该守护进程实现了 DVMRP 多播路由协议,并通过编辑 /usr/local/etc/mrouted.conf 来配置隧道和 DVMRP。安装 mrouted 时,还会安装 map-mbone 和 mrinfo,以及它们相关的 man 页面。请参考这些文档以获得配置示例。

DVMRP 已经在许多多播安装中被 PIM 协议取代。有关更多信息,请参阅 。

netstat(1)
routed(8)
ifconfig(8)
常见的路由表标志
route(8)
sysctl(8)
routed(8)
net/quagga
traceroute(8)
net/mrouted
pim(4)