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 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
  • 24.8.1. Xen™ Dom0 硬件要求
  • 24.8.2. Xen™ Dom0 控制域设置
  • 24.8.3. Xen™ DomU 虚拟机配置
  • 24.8.4. 故障排除
  • 24.8.4.1. 主机启动故障排除
  • 24.8.4.2. 虚拟机创建故障排除
在GitHub上编辑
导出为 PDF
  1. 第24章 虚拟化

24.8.基于 FreeBSD 的 Xen™ 虚拟机

上一页24.7.使用 FreeBSD 上的 bhyve 虚拟机下一页25.1.概述

最后更新于21天前

Xen 是一款 GPLv2 许可的 ,适用于 Intel® 和 ARM® 架构。FreeBSD 自 8.0 版本起支持 i386™ 和 AMD® 64 位 和 非特权域(虚拟机),并在 FreeBSD 11.0 中引入了 Dom0 控制域(主机)支持。FreeBSD 11 中已移除对 para-virtualized (PV) 域的支持,转而采用硬件虚拟化 (HVM) 域,这提供了更好的性能。

Xen™ 是一种裸金属虚拟机监控程序,意味着它是 BIOS 启动后加载的第一个程序。然后,启动一个特殊的特权虚拟机,称为 Domain-0(简称 Dom0)。Dom0 使用其特殊权限直接访问底层物理硬件,使其成为一种高性能解决方案。它能够直接访问磁盘控制器和网络适配器。Xen™ 管理工具由 Dom0 用来创建、列出和销毁虚拟机。Dom0 为非特权域提供虚拟磁盘和网络,通常称为 DomU。Xen™ Dom0 可以与其他虚拟化解决方案的服务控制台进行比较,而 DomU 是运行个别虚拟机的地方。

Xen™ 可以在不同的 Xen™ 服务器之间迁移虚拟机。当两个 Xen 主机共享相同的底层存储时,可以在不关闭虚拟机的情况下进行迁移。相反,迁移在 DomU 正常运行时进行,且无需重新启动或规划停机时间。这在维护或升级窗口中非常有用,确保 DomU 提供的服务仍然在运行。更多的 Xen™ 功能可以在 上找到。请注意,并非所有功能在 FreeBSD 上都得到支持。

24.8.1. Xen™ Dom0 硬件要求

要在主机上运行 Xen™ 虚拟机监控程序,需要特定的硬件功能。将 FreeBSD 作为 Xen 主机(Dom0)运行时,主机处理器需要支持 Intel 扩展页表()或 AMD 嵌套页表()以及输入/输出内存管理单元()功能。

注意

为了运行 FreeBSD 13 Xen™ Dom0,系统必须使用传统引导(BIOS)启动。FreeBSD 14 及更高版本支持在 BIOS 和 UEFI 模式下作为 Xen™ Dom0 启动。

24.8.2. Xen™ Dom0 控制域设置

用户应安装 和 包,这些包基于 Xen™ 4.18。

在安装 Xen 包之后,必须编辑配置文件,以准备主机进行 Dom0 集成。/etc/sysctl.conf 文件中的一个条目将禁用内存页数限制。否则,具有更高内存需求的 DomU 虚拟机将无法运行。

# echo 'vm.max_wired=-1' >> /etc/sysctl.conf

另一个与内存相关的设置是更改 /etc/login.conf,将 memorylocked 选项设置为 unlimited。否则,创建 DomU 域时可能会失败,出现 Cannot allocate memory 错误。更改 /etc/login.conf 后,运行 cap_mkdb 更新能力数据库。有关详细信息,请参阅 。

# sed -i '' -e 's/memorylocked=64K/memorylocked=unlimited/' /etc/login.conf
# cap_mkdb /etc/login.conf

在 /etc/ttys 文件中添加一个 Xen™ 控制台条目:

# echo 'xc0     "/usr/libexec/getty Pc"         xterm   onifconsole  secure' >> /etc/ttys

在 /boot/loader.conf 文件中选择一个 Xen™ 内核来激活 Dom0。Xen™ 还需要主机机器的 CPU 和内存资源供自己和其他 DomU 域使用。具体需要多少 CPU 和内存取决于个别需求和硬件能力。在此示例中,为 Dom0 分配了 8GB 内存和 4 个虚拟 CPU。还激活了串口控制台,并定义了日志选项。

对于 Xen 4.7 包,使用以下命令:

# echo 'hw.pci.mcfg=0' >> /boot/loader.conf
# echo 'if_tap_load="YES"' >> /boot/loader.conf
# echo 'xen_kernel="/boot/xen"' >> /boot/loader.conf
# echo 'xen_cmdline="dom0_mem=8192M dom0_max_vcpus=4 dom0pvh=1 console=com1,vga com1=115200,8n1 guest_loglvl=all loglvl=all"' >> /boot/loader.conf

对于 Xen 版本 4.11 及更高版本,应该使用以下命令:

# echo 'if_tap_load="YES"' >> /boot/loader.conf
# echo 'xen_kernel="/boot/xen"' >> /boot/loader.conf
# echo 'xen_cmdline="dom0_mem=8192M dom0_max_vcpus=4 dom0=pvh console=com1,vga com1=115200,8n1 guest_loglvl=all loglvl=all"' >> /boot/loader.conf

技巧

Xen™ 为 DomU 虚拟机创建的日志文件存储在 /var/log/xen 中。如果遇到问题,请务必检查该目录的内容。

在系统启动时启用 xencommons 服务:

# sysrc xencommons_enable=yes

这些设置足以启动一个启用 Dom0 的系统。但是,它缺少为 DomU 虚拟机提供网络功能。为了解决这个问题,定义一个桥接接口与主机系统的 NIC 连接,供 DomU 虚拟机使用。将 em0 替换为主机网络接口的名称。

# sysrc cloned_interfaces="bridge0"
# sysrc ifconfig_bridge0="addm em0 SYNCDHCP"
# sysrc ifconfig_em0="up"

重启主机以加载 Xen™ 内核并启动 Dom0。

# reboot

在成功启动 Xen™ 内核并再次登录系统后,使用 Xen™ 管理工具 xl 查看域的信息。

# xl list
Name                                        ID   Mem VCPUs      State   Time(s)
Domain-0                                     0  8192     4     r-----     962.0

24.8.3. Xen™ DomU 虚拟机配置

# fetch https://download.freebsd.org/releases/ISO-IMAGES/14.0/FreeBSD-14.0-RELEASE-amd64-bootonly.iso -o freebsd.iso

创建一个名为 xendisk0 的 20 GB ZFS 卷,用作虚拟机的磁盘空间。

# zfs create -V20G -o volmode=dev zroot/xendisk0

新的 DomU 虚拟机在一个文件中定义。也定义了一些特定的设置,如名称、键盘映射和 VNC 连接细节。以下 freebsd.cfg 包含了此示例的最小 DomU 配置:

# cat freebsd.cfg 
builder = "hvm" ①
name = "freebsd" ②
memory = 1024 ③
vcpus = 2 ④
vif = [ 'mac=00:16:3E:74:34:32,bridge=bridge0' ] ⑤
disk = [
'/dev/zvol/tank/xendisk0,raw,hda,rw', ⑥
'/root/freebsd.iso,raw,hdc:cdrom,r' ⑦
  ]
vnc = 1 ⑧
vnclisten = "0.0.0.0"
serial = "pty"
usbdevice = "tablet"

这些行的详细解释:

  • ① 这定义了使用何种虚拟化方式。hvm 表示硬件辅助虚拟化或硬件虚拟机。具有虚拟化扩展的 CPU 上,来宾操作系统可以不加修改地运行,提供几乎与运行在物理硬件上一样的性能。generic 是默认值,创建 PV 域。

  • ② 用于区分其他正在同一个 Dom0 上运行的虚拟机的名称。是必需的。

  • ③ 为虚拟机分配的内存量(以兆字节为单位)。该内存量从虚拟化管理程序的总可用内存中减去,而不是从 Dom0 的内存中减去。

  • ④ 分配给虚拟机的虚拟 CPU 数量。为了获得最佳性能,不要为来宾创建比物理 CPU 更多的虚拟 CPU。

  • ⑤ 虚拟网络适配器。这是连接到主机网络接口的桥接。mac 参数设置虚拟网络接口的 MAC 地址。此参数是可选的,如果没有提供 MAC,Xen™ 会生成一个随机的。

  • ⑥ 磁盘的完整路径、文件或 ZFS 卷,作为该虚拟机的磁盘存储。选项和多个磁盘定义之间由逗号分隔。

  • ⑦ 定义引导介质,用于安装初始操作系统。在此示例中,是之前下载的 ISO 镜像。请参考 Xen™ 文档了解其他类型的设备和选项设置。

  • ⑧ 控制 VNC 连接到 DomU 的串行控制台的选项。依次是:启用 VNC 支持,定义监听的 IP 地址,串行控制台的设备节点,以及输入方法(用于精确定位鼠标和其他输入方式)。keymap 定义使用的键盘映射,默认为 english。

创建好包含所有必要选项的文件后,可以通过将其作为参数传递给 xl create 来创建 DomU。

# xl create freebsd.cfg

注意

每次重启 Dom0 后,必须将配置文件传递给 xl create 以重新创建 DomU。默认情况下,重启后只会创建 Dom0,而不会创建单独的虚拟机。虚拟机可以继续运行,因为它们的操作系统存储在虚拟磁盘上。虚拟机配置可能会随着时间的推移而变化(例如,添加更多内存)。虚拟机配置文件必须妥善备份并保留,以便在需要时重新创建虚拟机。

执行 xl list 命令的输出确认已创建 DomU。

# xl list
Name                                        ID   Mem VCPUs      State   Time(s)
Domain-0                                     0  8192     4     r-----  1653.4
freebsd                                      1  1024     1     -b----   663.9

要开始安装基础操作系统,启动 VNC 客户端,并将其指向主机的网络地址或在 freebsd.cfg 中定义的 vnclisten 行的 IP 地址。操作系统安装完成后,关闭 DomU 并断开 VNC 查看器。编辑 freebsd.cfg,删除或注释掉 cdrom 定义的行(在行首插入 # 字符)。要加载新的配置,需要先使用 xl destroy 销毁旧的 DomU,传递虚拟机名称或 ID 作为参数。然后,使用修改后的 freebsd.cfg 重新创建虚拟机。

# xl destroy freebsd
# xl create freebsd.cfg

此时,可以再次使用 VNC 查看器访问虚拟机。这次,它将从安装有操作系统的虚拟磁盘启动,并可以作为虚拟机使用。

24.8.4. 故障排除

本节包含了一些基本信息,旨在帮助排除在使用 FreeBSD 作为 Xen™ 主机或虚拟机时可能遇到的问题。

24.8.4.1. 主机启动故障排除

请注意,以下故障排除技巧适用于 Xen™ 4.11 或更新版本。如果你仍在使用 Xen™ 4.7 并遇到问题,建议迁移到更新版本的 Xen™。

为了解决主机启动问题,你可能需要串行电缆或调试 USB 电缆。可以通过在 loader.conf 中添加选项来获取详细的 Xen™ 启动输出。以下是一些相关的调试选项:

  • iommu=debug:可以用来打印关于 IOMMU 的额外诊断信息。

  • dom0=verbose:可以用来打印关于 Dom0 构建过程的额外诊断信息。

  • sync_console:强制同步控制台输出的标志。对于调试非常有用,可以避免因限速而丢失消息。切勿在生产环境中使用此选项,因为它可能允许恶意的虚拟机通过控制台对 Xen™ 发起拒绝服务攻击。

FreeBSD 还应该以详细模式启动,以便识别任何问题。要激活详细启动模式,可以运行以下命令:

# echo 'boot_verbose="YES"' >> /boot/loader.conf

24.8.4.2. 虚拟机创建故障排除

在创建虚拟机时也可能会遇到问题,以下提供了一些帮助,帮助诊断虚拟机创建问题。

虚拟机创建失败的最常见原因是 xl 命令输出某些错误,并以非 0 的返回码退出。如果提供的错误信息不足以帮助识别问题,可以通过多次使用 v 选项从 xl 获取更详细的输出。

# xl -vvv create freebsd.cfg
Parsing config from freebsd.cfg
libxl: debug: libxl_create.c:1693:do_domain_create: Domain 0:ao 0x800d750a0: create: how=0x0 callback=0x0 poller=0x800d6f0f0
libxl: debug: libxl_device.c:397:libxl__device_disk_set_backend: Disk vdev=xvda spec.backend=unknown
libxl: debug: libxl_device.c:432:libxl__device_disk_set_backend: Disk vdev=xvda, using backend phy
libxl: debug: libxl_create.c:1018:initiate_domain_create: Domain 1:running bootloader
libxl: debug: libxl_bootloader.c:328:libxl__bootloader_run: Domain 1:not a PV/PVH domain, skipping bootloader
libxl: debug: libxl_event.c:689:libxl__ev_xswatch_deregister: watch w=0x800d96b98: deregister unregistered
domainbuilder: detail: xc_dom_allocate: cmdline="", features=""
domainbuilder: detail: xc_dom_kernel_file: filename="/usr/local/lib/xen/boot/hvmloader"
domainbuilder: detail: xc_dom_malloc_filemap    : 326 kB
libxl: debug: libxl_dom.c:988:libxl__load_hvm_firmware_module: Loading BIOS: /usr/local/share/seabios/bios.bin
...

输出确认了 Dom0(称为 Domain-0)的 ID 为 0,并且正在运行。它还具有在 /boot/loader.conf 中定义的内存和虚拟 CPU。更多信息可以参考 。现在可以创建 DomU 虚拟机。

无特权域由配置文件和虚拟或物理硬盘组成。DomU 的虚拟磁盘存储可以是通过 创建的文件,也可以是如在 中所描述的 ZFS 卷。在这个例子中,使用了一个 20 GB 的卷。创建一个虚拟机,使用 ZFS 卷、FreeBSD ISO 镜像、1 GB 的内存和两个虚拟 CPU。ISO 安装文件通过 下载并保存在名为 freebsd.iso 的本地文件中。

如果这些选项都无法帮助解决问题,请将串行启动日志发送到 和 以便进一步分析。

如果详细输出仍无法帮助诊断问题,还可以查看 /var/log/xen 中的 QEMU 和 Xen™ 工具栈日志。请注意,日志文件名会附加上域的名称,因此,如果域名为 freebsd,你应该会找到 /var/log/xen/xl-freebsd.log 和可能的 /var/log/xen/qemu-dm-freebsd.log。这两个日志文件中可能包含有用的调试信息。如果这些都没有帮助解决问题,请将你遇到的问题描述和尽可能多的信息发送到 和 以获得帮助。

类型 1 虚拟机监控程序
DomU
Amazon EC2
Xen Wiki 概述页面
EPT
NPT
IOMMU
emulators/xen-kernel
sysutils/xen-tools
资源限制
Xen™ 文档
truncate(1)
“创建和销毁卷”
fetch(1)
freebsd-xen@FreeBSD.org
xen-devel@lists.xenproject.org
freebsd-xen@FreeBSD.org
xen-devel@lists.xenproject.org