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 提供支持
在本页
  • 20.14.1. HAST 操作
  • 20.14.2. HAST 配置
  • 20.14.2.1. 故障切换配置
  • 20.14.3. 故障排除
  • 20.14.3.1. 从脑裂状态恢复
在GitHub上编辑
导出为 PDF
  1. 第20章 存储

20.14.高可用性存储(HAST)

上一页20.13.加密交换分区下一页21.1.概述

最后更新于6天前

LogoLogo

FreeBSD 中文社区(CFC) 2025

高可用性是严肃商业应用的主要要求之一,而高可用存储是此类环境中的关键组成部分。在 FreeBSD 中,高可用存储(HAST)框架允许通过 TCP/IP 网络将相同数据透明地存储在几台物理分离的机器上。HAST 可以理解为基于网络的 RAID1(镜像),类似于 GNU/Linux® 平台上的 DRBD® 存储系统。结合 FreeBSD 的其他高可用性功能,如 CARP,HAST 使得构建一个能够抵御硬件故障的高可用存储集群成为可能。

以下是 HAST 的主要特性:

  • 可以用于屏蔽本地硬盘的 I/O 错误。

  • 文件系统无关,能够与 FreeBSD 支持的任何文件系统一起工作。

  • 高效且快速的重新同步,只同步节点停机期间被修改的块。

  • 可以在已经部署的环境中添加额外的冗余。

  • 与 CARP、Heartbeat 或其他工具结合使用,可以构建一个强大且耐用的存储系统。

阅读完本节后,你将了解:

  • 什么是 HAST,它是如何工作的,提供了哪些功能。

  • 如何在 FreeBSD 上设置和使用 HAST。

  • 如何集成 CARP 和 devd(8) 来构建一个强大的存储系统。

在阅读本节之前,你应该:

  • 理解 UNIX® 和 FreeBSD 基础知识()。

  • 知道如何配置网络接口和其他核心 FreeBSD 子系统()。

  • 对 FreeBSD 网络有较好的理解()。

HAST 项目由 FreeBSD 基金会赞助,并得到了 和 的支持。

20.14.1. HAST 操作

HAST 提供了两台物理机器之间的同步块级复制:主节点和从节点。这两台机器一起被称为集群。

由于 HAST 采用主从配置,它允许在任何给定时间只有一个集群节点处于活动状态。主节点,也称为活动节点,将处理所有针对 HAST 管理设备的 I/O 请求。从节点会自动从主节点同步数据。

HAST 系统的物理组件包括主节点上的本地磁盘和远程从节点上的磁盘。

HAST 在块级上同步操作,使其对文件系统和应用程序透明。HAST 在 /dev/hast/ 中提供常规 GEOM 提供程序,供其他工具或应用程序使用。使用 HAST 提供的设备与使用原始磁盘或分区没有区别。

每次写入、删除或刷新操作都会同时发送到本地磁盘和远程磁盘,数据通过 TCP/IP 传输。每次读操作默认从本地磁盘提供,除非本地磁盘未更新或发生了 I/O 错误。在这种情况下,读操作将发送到从节点。

HAST 旨在提供快速的故障恢复。因此,在节点故障后减少同步时间非常重要。为了提供快速同步,HAST 管理磁盘上的脏区位图,并且仅同步这些脏区,在常规同步时进行,初始同步除外。

有许多方法可以处理同步。HAST 实现了几种复制模式以处理不同的同步方法:

  • memsync:此模式在本地写操作完成且远程节点确认数据到达时报告写操作完成,但在实际存储数据之前就报告完成。远程节点上的数据将在收到确认后直接存储。此模式旨在减少延迟,但仍提供良好的可靠性。此模式是默认模式。

  • fullsync:此模式在本地写操作和远程写操作都完成时报告写操作完成。这是最安全但也是最慢的复制模式。

  • async:此模式在本地写操作完成时报告写操作完成。这是最快但最危险的复制模式。它仅应在复制到延迟过高的远程节点时使用。

20.14.2. HAST 配置

HAST 框架由多个组件组成:

options	GEOM_GATE

以下示例描述了如何使用 HAST 配置两台节点的主从操作,以便在两台机器之间复制数据。这些节点将被称为 hasta,其 IP 地址为 172.16.0.1,以及 hastb,其 IP 地址为 172.16.0.2。两台节点将有一个大小相同的专用硬盘 /dev/ad6 用于 HAST 操作。HAST 池,有时称为资源或 GEOM 提供程序,在 /dev/hast/ 中将被称为 test。

HAST 的配置是通过 /etc/hast.conf 完成的。该文件在两台节点上应相同。最简单的配置是:

resource test {
	on hasta {
		local /dev/ad6
		remote 172.16.0.2
	}
	on hastb {
		local /dev/ad6
		remote 172.16.0.1
	}
}

技巧

如果主机可解析,并且在 /etc/hosts 或本地 DNS 中定义,亦可在 remote 语句中使用主机名。

# hastctl create test
# service hastd onestart

注意

不 能使用已存在的文件系统与 GEOM 提供程序一起使用,也不能将现有存储转换为 HAST 管理的池。此过程需要在提供程序上存储一些元数据,而现有提供程序上没有足够的空间。

# hastctl role primary test

在从节点 hastb 上运行此命令:

# hastctl role secondary test

通过在每个节点上运行 hastctl 来验证结果:

# hastctl status test

检查输出中的 status 行。如果显示为 degraded,则说明配置文件有问题。它应该在每个节点上显示为 complete,这意味着节点之间的同步已经开始。当 hastctl status 报告 dirty 区域的字节数为 0 时,表示同步已完成。

下一步是在 GEOM 提供程序上创建文件系统并挂载它。这必须在 primary 节点上完成。创建文件系统可能需要几分钟,具体取决于硬盘的大小。此示例在 /dev/hast/test 上创建一个 UFS 文件系统:

# newfs -U /dev/hast/test
# mkdir /hast/test
# mount /dev/hast/test /hast/test

待 HAST 框架正确配置,最后一步是确保 HAST 在系统启动时自动启动。将以下行添加到 /etc/rc.conf 中:

hastd_enable="YES"

20.14.2.1. 故障切换配置

本示例的目标是构建一个强大的存储系统,能够抵御任意节点的故障。如果主节点发生故障,备份节点将无缝接管,检查并挂载文件系统,继续工作,不会丢失任何数据。

上一节中创建的 HAST 池现在已经准备好可以导出到网络上的其他主机。这可以通过使用共享 IP 地址 172.16.0.254 通过 NFS 或 Samba 完成。唯一未解决的问题是,在主节点故障时自动进行故障切换。

为了捕获 CARP 接口的状态变化,请在每个节点的 /etc/devd.conf 中添加以下配置,同时将 <vhid> 替换为虚拟主机 ID,将 <ifname> 替换为相关的接口名称:

notify 30 {
	match "system" "CARP";
	match "subsystem" "<vhid>@<ifname>";
	match "type" "MASTER";
	action "/usr/local/sbin/carp-hast-switch primary";
};

notify 30 {
	match "system" "CARP";
	match "subsystem" "<vhid>@<ifname>";
	match "type" "BACKUP";
	action "/usr/local/sbin/carp-hast-switch secondary";
};
# service devd restart

以下是一个自动故障切换脚本的示例:

#!/bin/sh

# 原始脚本由 Freddie Cash <fjwcash@gmail.com> 编写
# 由 Michael W. Lucas <mwlucas@BlackHelicopters.org> 和 Viktor Petersson <vpetersson@wireload.net> 修改

# HAST 资源的名称,如 /etc/hast.conf 中所列
resources="test"

# 成为主节点后延迟挂载 HAST 资源
# 请根据实际情况进行调整
delay=3

# 日志记录
log="local0.debug"
name="carp-hast"

# 用户可配置项结束

case "$1" in
	primary)
		logger -p $log -t $name "Switching to primary provider for ${resources}."
		sleep ${delay}

		# 等待所有 "hastd secondary" 进程停止
		for disk in ${resources}; do
			while $( pgrep -lf "hastd: ${disk} \(secondary\)" > /dev/null 2>&1 ); do
				sleep 1
			done

			# 为每个磁盘切换角色
			hastctl role primary ${disk}
			if [ $? -ne 0 ]; then
				logger -p $log -t $name "Unable to change role to primary for resource ${disk}."
				exit 1
			fi
		done

		# 等待 /dev/hast/* 设备出现
		for disk in ${resources}; do
			for I in $( jot 60 ); do
				[ -c "/dev/hast/${disk}" ] && break
				sleep 0.5
			done

			if [ ! -c "/dev/hast/${disk}" ]; then
				logger -p $log -t $name "GEOM provider /dev/hast/${disk} did not appear."
				exit 1
			fi
		done

		logger -p $log -t $name "Role for HAST resources ${resources} switched to primary."

		logger -p $log -t $name "Mounting disks."
		for disk in ${resources}; do
			mkdir -p /hast/${disk}
			fsck -p -y -t ufs /dev/hast/${disk}
			mount /dev/hast/${disk} /hast/${disk}
		done

	;;

	secondary)
		logger -p $log -t $name "Switching to secondary provider for ${resources}."

		# 切换 HAST 资源的角色
		for disk in ${resources}; do
			if ! mount | grep -q "^/dev/hast/${disk} on "
			then
			else
				umount -f /hast/${disk}
			fi
			sleep $delay
			hastctl role secondary ${disk} 2>&1
			if [ $? -ne 0 ]; then
				logger -p $log -t $name "Unable to switch role to secondary for resource ${disk}."
				exit 1
			fi
			logger -p $log -t $name "Role switched to secondary for resource ${disk}."
		done
	;;
esac

简而言之,当节点成为主节点时,脚本执行以下操作:

  • 将 HAST 池提升为主节点。

  • 检查 HAST 池下的文件系统。

  • 挂载该池。

当节点成为从节点时:

  • 卸载 HAST 池。

  • 将 HAST 池降级为从节点。

当心

这是一个示例脚本,仅作为概念验证。它没有处理所有可能的场景,可以根据需要进行扩展或修改,例如启动或停止所需的服务。

技巧

本示例中使用了标准的 UFS 文件系统。为了减少恢复所需的时间,可以改用启用日志功能的 UFS 或 ZFS 文件系统。

20.14.3. 故障排除

HAST 通常应无问题地工作。然而,像其他任何软件产品一样,有时它可能无法按预期工作。问题的来源可能各不相同,但基本规则是确保集群节点之间的时间同步。

在故障排除 HAST 时,应通过启动 hastd 并使用 -d 增加调试级别。可以多次指定此参数,以进一步增加调试级别。还可以考虑使用 -F,该选项会使 hastd 在前台运行。

20.14.3.1. 从脑裂状态恢复

脑裂 状态发生在集群的节点无法相互通信时,且两者都被配置为主节点。这是一个危险的状态,因为它允许两个节点对数据进行不兼容的更改。该问题必须由系统管理员手动修复。

管理员必须决定哪个节点的更改更为重要,或者手动进行合并。然后,让 HAST 对有问题的数据节点执行完全同步。为此,在需要重新同步的节点上执行以下命令:

# hastctl role init test
# hastctl create test
# hastctl role secondary test

提供数据同步的 守护进程。启动此守护进程时,它会自动加载 geom_gate.ko。

用户空间管理工具 。

配置文件。该文件必须在启动 hastd 之前存在。

希望将 GEOM_GATE 支持静态编译到内核中的用户,应在自定义内核配置文件中添加以下行,然后按照 中的说明重新编译内核:

有关更高级的配置,请参阅 。

配置文件在两台节点上存在后,可以创建 HAST 池。在两台节点上运行以下命令,将初始元数据放置到本地磁盘并启动 :

HAST 节点的 primary 或 secondary 角色由管理员或像 Heartbeat 这样的软件通过 选择。在主节点 hasta 上,执行以下命令:

为实现这一任务,使用了通用地址冗余协议(CARP)来提供 IP 层的自动故障切换。CARP 允许同一网络段上的多个主机共享一个 IP 地址。根据 中的文档,在两个节点上设置 CARP。在此示例中,每个节点将有自己的管理 IP 地址,并且共享一个 IP 地址 172.16.0.254。集群的主 HAST 节点必须是主 CARP 节点。

在 CARP 接口状态变化时,FreeBSD 操作系统会生成一个 事件,这使得可以监控 CARP 接口的状态变化。CARP 接口的状态变化表明某个节点故障或重新上线。这些状态变化事件使得能够运行一个脚本来自动处理 HAST 故障切换。

在两台节点上重启 ,以使新配置生效:

当指定接口的状态变化时,系统会生成通知,允许 子系统运行指定的自动故障切换脚本 /usr/local/sbin/carp-hast-switch。有关此配置的更多说明,请参阅 。

除了将高可用存储本地使用外,还可以通过 、、 或 ports 中的程序(例如 )将其共享给网络上的其他计算机。

更多详细信息和示例可以在 找到。

FreeBSD 基础
配置与调优
网络通信
http://www.omc.net/
http://www.transip.nl/
hastd(8)
hastctl(8)
hast.conf(5)
配置 FreeBSD 内核
hast.conf(5)
hastd(8)
hastctl(8)
“通用地址冗余协议(CARP)”
devd(8)
devd(8)
devd(8)
devd.conf(5)
NFS
iSCSI
sshfs(1)
net/samba419
http://wiki.FreeBSD.org/HAST