# 17.2.jail 的类型

一些管理员会将 jail 分为不同的类型，尽管它们在底层技术上是相同的。每位管理员需要根据所要解决的问题来评估应创建哪种类型的 jail。

以下列出了不同类型的 jail，它们的特征，以及使用时需要考虑的事项。

## 17.2.1. 厚 jail（Thick Jails）

厚 jail 是 FreeBSD Jail 的传统形式。在厚 jail 中，会在 jail 环境中复制一整套基本系统。这意味着 jail 拥有一套独立的 FreeBSD 基本系统实例，包括库、可执行文件和配置文件。这个 jail 可以被视为一个几乎完整、独立的 FreeBSD 安装实例，但它运行在宿主系统的控制之下。这种隔离确保 jail 内部的进程与宿主系统和其他 jail 相互独立。

**厚 jail 的优点：**

* **高度隔离**：jail 内部的进程与宿主系统和其他 jail 保持隔离。
* **独立性**：厚 jail 可以拥有与宿主系统或其他 jail 不同版本的库、配置和软件。
* **安全性**：由于 jail 拥有自己的基本系统，影响 jail 环境的漏洞或问题不会直接影响宿主或其他 jail。

**厚 jail 的缺点：**

* **资源开销**：由于每个 jail 都维护一套独立的基本系统，与薄 jail 相比会消耗更多资源。
* **维护成本**：每个 jail 的基本系统组件都需要独立维护和更新。

## 17.2.2. 薄 jail（Thin Jail）

薄 jail 使用 OpenZFS 快照或 NullFS 挂载，从模板中共享基本系统。每个薄 jail 只复制基本系统的最小子集，因此相比厚 jail 消耗的资源更少。但这也意味着薄 jail 的隔离性和独立性较差。共享组件的变动可能会同时影响多个薄 jail。

简而言之，FreeBSD 薄 jail 是一种在隔离环境中复制了大量（但不是全部）基本系统的 FreeBSD Jail 类型。

**薄 jail 的优点：**

* **资源效率高**：薄 jail 相比厚 jail 更节省资源。由于大部分基本系统是共享的，磁盘空间和内存占用较少。这使得可以在同一硬件上运行更多 jail，而不会消耗过多资源。
* **部署更快**：创建和启动薄 jail 通常比厚 jail 更快速，尤其适合快速部署多个实例。
* **维护统一**：由于大部分基本系统是与宿主共享的，像库和二进制等通用组件的更新只需在宿主系统中进行一次。与为每个厚 jail 独立维护基本系统相比，这大大简化了维护工作。
* **资源共享**：薄 jail 更容易与宿主系统共享库和二进制文件，这可能带来更高效的磁盘缓存，并提升 jail 中应用的性能。

**薄 jail 的缺点：**

* **隔离性较差**：薄 jail 的主要缺点是隔离性较弱。由于共享大量模板基本系统，如果这些共享组件存在漏洞或问题，可能会同时影响多个 jail。
* **安全隐患**：隔离性降低可能带来安全风险，一个 jail 被攻破后，可能对其他 jail 或宿主系统造成更大影响。
* **依赖冲突**：如果多个薄 jail 需要不同版本的库或软件，依赖管理可能会变得复杂，有时需要额外的努力以确保兼容性。
* **兼容性问题**：在薄 jail 中运行的应用，若假设存在某些特定的基本系统环境，而这些组件可能在模板中未包含或版本不同，则可能引发兼容性问题。

## 17.2.3. 服务 jail（Service Jails）

服务 jail 直接与宿主系统共享整个文件系统树（jail 的根路径为 **/**），因此可以访问并修改宿主上的任何文件，同时也与宿主系统共享相同的用户账户。默认情况下，它无法访问网络或其他 jail 所限制的资源，但可以配置为复用宿主的网络，并移除部分 jail 限制。服务 jail 的使用场景是，在无需对服务或守护进程所需文件有任何了解的情况下，自动将其限制在一个 jail 中，且几乎无需配置。服务 jail 从 FreeBSD 15 开始可用。

**服务 jail 的优点：**

* **零管理**：一个已支持服务 jail 的服务只需在 **/etc/rc.conf** 中写一行配置；不支持的服务则需要写两行。
* **资源效率高**：服务 jail 比薄 jail 更节省资源，因为它们不需要额外的磁盘空间或网络资源。
* **部署更快**：如果只是将不同的服务或守护进程隔离，而不需要运行同一服务/守护进程的多个实例，那么服务 jail 的创建和启动速度通常比薄 jail 更快。
* **资源共享**：服务 jail 与宿主系统共享所有资源（如库和二进制文件），这可能带来更高效的磁盘缓存和更好的应用性能。
* **进程隔离**：服务 jail 会隔离特定服务，它无法看到不是其子进程的其他进程，即使它们运行在同一用户账户下。

**服务 jail 的缺点：**

* **隔离性较差**：服务 jail 与厚 jail 或薄 jail 相比没有文件系统隔离。
* **安全隐患**：由于隔离性差，一个 jail 的被攻破可能会对宿主系统上的所有内容造成影响。

下面将讨论的大多数 jail 配置内容对于服务 jail 来说并不适用。为了理解 jail 的工作原理，建议首先了解这些配置选项。关于配置服务 jail 的具体细节，请参见 [配置服务 jail](https://docs.freebsd.org/en/books/handbook/jails/#service-jails-config)。

## 17.2.4. VNET Jail

FreeBSD 的 VNET jail 是一种虚拟化环境，允许对 jail 中运行的进程进行网络资源的隔离与控制。它通过为 jail 中的进程创建一个独立的网络协议栈，实现了高度的网络分段与安全性，从而确保 jail 中的网络流量不会与宿主系统或其他 jail 混合。

本质上，FreeBSD 的 VNET jail 增加了一套网络配置机制。这意味着 VNET jail 可以作为厚 jail 或薄 jail 创建。

## 17.2.5. Linux Jail

FreeBSD 的 Linux Jail 是 FreeBSD 操作系统中的一项功能，能在 jail 中运行 Linux 二进制文件和应用程序。通过集成一层兼容层，将部分 Linux 系统调用和库转换为可由 FreeBSD 内核执行的形式，从而实现此功能。Linux Jail 的目的是在无需单独部署 Linux 虚拟机或运行环境的情况下，使 FreeBSD 系统能运行 Linux 软件。


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://book.bsdcn.org/hanbook/di-17-zhang-jail-yu-rong-qi/17.2.jail-de-lei-xing.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
