Compare commits
7 Commits
b60be82a34
...
39bad4ef90
Author | SHA1 | Date | |
---|---|---|---|
|
39bad4ef90 | ||
|
0b9f464575 | ||
|
4be063afb1 | ||
|
0644534902 | ||
|
a986752f77 | ||
|
d61a703a0c | ||
|
bfe1b17c88 |
3
.gitignore
vendored
3
.gitignore
vendored
@ -54,4 +54,5 @@ Temporary Items
|
||||
.apdisk
|
||||
|
||||
# Production
|
||||
node_modules/
|
||||
node_modules/
|
||||
.vitepress/cache/
|
22
.vitepress/cache/deps/_metadata.json
vendored
22
.vitepress/cache/deps/_metadata.json
vendored
@ -1,31 +1,31 @@
|
||||
{
|
||||
"hash": "72ee1963",
|
||||
"configHash": "63f5bf89",
|
||||
"hash": "97080672",
|
||||
"configHash": "e0404c79",
|
||||
"lockfileHash": "dcd677dd",
|
||||
"browserHash": "44aba596",
|
||||
"browserHash": "3de085d8",
|
||||
"optimized": {
|
||||
"vue": {
|
||||
"src": "../../../node_modules/vue/dist/vue.runtime.esm-bundler.js",
|
||||
"src": "../../../node_modules/.store/vue@3.5.13/node_modules/vue/dist/vue.runtime.esm-bundler.js",
|
||||
"file": "vue.js",
|
||||
"fileHash": "53df15be",
|
||||
"fileHash": "ae5a8a1c",
|
||||
"needsInterop": false
|
||||
},
|
||||
"vitepress > @vue/devtools-api": {
|
||||
"src": "../../../node_modules/@vue/devtools-api/dist/index.js",
|
||||
"src": "../../../node_modules/.store/@vue+devtools-api@7.6.8/node_modules/@vue/devtools-api/dist/index.js",
|
||||
"file": "vitepress___@vue_devtools-api.js",
|
||||
"fileHash": "394d0563",
|
||||
"fileHash": "d4b049e5",
|
||||
"needsInterop": false
|
||||
},
|
||||
"vitepress > @vueuse/core": {
|
||||
"src": "../../../node_modules/@vueuse/core/index.mjs",
|
||||
"src": "../../../node_modules/.store/@vueuse+core@11.3.0/node_modules/@vueuse/core/index.mjs",
|
||||
"file": "vitepress___@vueuse_core.js",
|
||||
"fileHash": "5841a618",
|
||||
"fileHash": "485aa128",
|
||||
"needsInterop": false
|
||||
}
|
||||
},
|
||||
"chunks": {
|
||||
"chunk-VJWGEPT5": {
|
||||
"file": "chunk-VJWGEPT5.js"
|
||||
"chunk-XEHQW2X6": {
|
||||
"file": "chunk-XEHQW2X6.js"
|
||||
}
|
||||
}
|
||||
}
|
12542
.vitepress/cache/deps/chunk-VJWGEPT5.js
vendored
12542
.vitepress/cache/deps/chunk-VJWGEPT5.js
vendored
File diff suppressed because it is too large
Load Diff
7
.vitepress/cache/deps/chunk-VJWGEPT5.js.map
vendored
7
.vitepress/cache/deps/chunk-VJWGEPT5.js.map
vendored
File diff suppressed because one or more lines are too long
@ -1,4 +1,4 @@
|
||||
// node_modules/@vue/devtools-shared/dist/index.js
|
||||
// node_modules/.store/@vue+devtools-shared@7.6.8/node_modules/@vue/devtools-shared/dist/index.js
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
@ -258,7 +258,7 @@ function isUrlString(str) {
|
||||
}
|
||||
var deepClone = (0, import_rfdc.default)({ circles: true });
|
||||
|
||||
// node_modules/perfect-debounce/dist/index.mjs
|
||||
// node_modules/.store/perfect-debounce@1.0.0/node_modules/perfect-debounce/dist/index.mjs
|
||||
var DEBOUNCE_DEFAULTS = {
|
||||
trailing: true
|
||||
};
|
||||
@ -315,7 +315,7 @@ async function _applyPromised(fn, _this, args) {
|
||||
return await fn.apply(_this, args);
|
||||
}
|
||||
|
||||
// node_modules/hookable/dist/index.mjs
|
||||
// node_modules/.store/hookable@5.5.3/node_modules/hookable/dist/index.mjs
|
||||
function flatHooks(configHooks, hooks2 = {}, parentName) {
|
||||
for (const key in configHooks) {
|
||||
const subHook = configHooks[key];
|
||||
@ -520,11 +520,11 @@ function createHooks() {
|
||||
return new Hookable();
|
||||
}
|
||||
|
||||
// node_modules/birpc/dist/index.mjs
|
||||
// node_modules/.store/birpc@0.2.19/node_modules/birpc/dist/index.mjs
|
||||
var { clearTimeout: clearTimeout2, setTimeout: setTimeout2 } = globalThis;
|
||||
var random = Math.random.bind(Math);
|
||||
|
||||
// node_modules/@vue/devtools-kit/dist/index.js
|
||||
// node_modules/.store/@vue+devtools-kit@7.6.8/node_modules/@vue/devtools-kit/dist/index.js
|
||||
var __create2 = Object.create;
|
||||
var __defProp2 = Object.defineProperty;
|
||||
var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor;
|
||||
|
File diff suppressed because one or more lines are too long
@ -34,9 +34,9 @@ import {
|
||||
version,
|
||||
watch,
|
||||
watchEffect
|
||||
} from "./chunk-VJWGEPT5.js";
|
||||
} from "./chunk-XEHQW2X6.js";
|
||||
|
||||
// node_modules/vitepress/lib/vue-demi.mjs
|
||||
// node_modules/.store/vitepress@1.5.0/node_modules/vitepress/lib/vue-demi.mjs
|
||||
var isVue2 = false;
|
||||
var isVue3 = true;
|
||||
function set(target, key, val) {
|
||||
@ -56,7 +56,7 @@ function del(target, key) {
|
||||
delete target[key];
|
||||
}
|
||||
|
||||
// node_modules/@vueuse/shared/index.mjs
|
||||
// node_modules/.store/@vueuse+shared@11.3.0/node_modules/@vueuse/shared/index.mjs
|
||||
function computedEager(fn, options) {
|
||||
var _a;
|
||||
const result = shallowRef();
|
||||
@ -1560,7 +1560,7 @@ function whenever(source, cb, options) {
|
||||
return stop;
|
||||
}
|
||||
|
||||
// node_modules/@vueuse/core/index.mjs
|
||||
// node_modules/.store/@vueuse+core@11.3.0/node_modules/@vueuse/core/index.mjs
|
||||
function computedAsync(evaluationCallback, initialState, optionsOrRef) {
|
||||
let options;
|
||||
if (isRef(optionsOrRef)) {
|
||||
|
File diff suppressed because one or more lines are too long
2
.vitepress/cache/deps/vue.js
vendored
2
.vitepress/cache/deps/vue.js
vendored
@ -168,7 +168,7 @@ import {
|
||||
withMemo,
|
||||
withModifiers,
|
||||
withScopeId
|
||||
} from "./chunk-VJWGEPT5.js";
|
||||
} from "./chunk-XEHQW2X6.js";
|
||||
export {
|
||||
BaseTransition,
|
||||
BaseTransitionPropsValidators,
|
||||
|
@ -12,19 +12,30 @@ export default defineConfig({
|
||||
],
|
||||
|
||||
sidebar: {
|
||||
'/docs/engine': [
|
||||
'/': [
|
||||
{
|
||||
text: "引擎",
|
||||
link: '/docs/engine/',
|
||||
items: [
|
||||
{ text: '概述', link: '/docs/engine/' },
|
||||
{
|
||||
text: '安装',
|
||||
collapsed: false,
|
||||
collapsed: true,
|
||||
link: '/docs/engine/about',
|
||||
items: [
|
||||
{ text: "Ubuntu", link: '/docs/engine/ubuntu' },
|
||||
{ text: "Debian", link: '/docs/engine/debian' },
|
||||
]
|
||||
},
|
||||
{
|
||||
text: '存储',
|
||||
collapsed: true,
|
||||
link: '/docs/storage/',
|
||||
items: [
|
||||
{ text: "卷", link: '/docs/storage/volume' },
|
||||
{ text: "绑定挂载", link: '/docs/storage/volume' },
|
||||
{ text: "tmpfs 挂载", link: '/docs/storage/volume' },
|
||||
{ text: "存储驱动程序", link: '/docs/storage/volume' },
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
|
@ -4,7 +4,7 @@ outline: [2,4]
|
||||
|
||||
# 在 Debian 上安装 Docker Engine
|
||||
|
||||
要在 Debian 上开始使用 Docker Engine,请确保您 [满足先决条件](#先决条件),然后按照 [安装步骤](#安装方法)进行操作。
|
||||
要在 Debian 上开始使用 Docker Engine,请确保你 [满足先决条件](#先决条件),然后按照 [安装步骤](#安装方法)进行操作。
|
||||
|
||||
## 先决条件
|
||||
### 防火墙限制
|
||||
@ -12,21 +12,21 @@ outline: [2,4]
|
||||
在安装 Docker 之前,请确保考虑以下安全隐患和防火墙不兼容性。
|
||||
:::
|
||||
|
||||
- 如果您使用 ufw 或firewalld 来管理防火墙设置,请注意,当您使用 Docker 公开容器端口时,这些端口会绕过防火墙规则。有关更多信息,请参阅 [Docker 和 ufw](https://docs.docker.com/engine/network/packet-filtering-firewalls/#docker-and-ufw)。
|
||||
- Docker 仅与`iptables-nft`和兼容`iptables-legacy`。使用 创建的防火墙规则`nft`在安装了 Docker 的系统上不受支持。确保您使用的任何防火墙规则集都是使用`iptables`或创建的`ip6tables`,并且将它们添加到`DOCKER-USER`链中,请参阅 [数据包过滤和防火墙](https://docs.docker.com/engine/network/packet-filtering-firewalls/)。
|
||||
- 如果你使用 ufw 或firewalld 来管理防火墙设置,请注意,当你使用 Docker 公开容器端口时,这些端口会绕过防火墙规则。有关更多信息,请参阅 [Docker 和 ufw](https://docs.docker.com/engine/network/packet-filtering-firewalls/#docker-and-ufw)。
|
||||
- Docker 仅与`iptables-nft`和兼容`iptables-legacy`。使用 创建的防火墙规则`nft`在安装了 Docker 的系统上不受支持。确保你使用的任何防火墙规则集都是使用`iptables`或创建的`ip6tables`,并且将它们添加到`DOCKER-USER`链中,请参阅 [数据包过滤和防火墙](https://docs.docker.com/engine/network/packet-filtering-firewalls/)。
|
||||
|
||||
### 操作系统要求
|
||||
|
||||
要安装 Docker Engine,您需要以下 Debian 版本之一的 64 位版本:
|
||||
要安装 Docker Engine,你需要以下 Debian 版本之一的 64 位版本:
|
||||
|
||||
- Debian Bookworm 12(稳定版)
|
||||
- Debian Bullseye 11(旧稳定版)
|
||||
Debian 的 Docker Engine 与 x86_64(或 amd64)、armhf、arm64 和 ppc64le(ppc64el)架构兼容。
|
||||
|
||||
### 卸载旧版本
|
||||
在安装 Docker Engine 之前,您需要卸载所有有冲突的软件包。
|
||||
在安装 Docker Engine 之前,你需要卸载所有有冲突的软件包。
|
||||
|
||||
您的 Linux 发行版可能提供了非官方的 Docker 软件包,这些软件包可能会与 Docker 提供的官方软件包冲突。您必须在安装 Docker Engine 正式版之前卸载这些软件包。
|
||||
你的 Linux 发行版可能提供了非官方的 Docker 软件包,这些软件包可能会与 Docker 提供的官方软件包冲突。你必须在安装 Docker Engine 正式版之前卸载这些软件包。
|
||||
|
||||
要卸载的非官方软件包包括:
|
||||
|
||||
@ -35,7 +35,7 @@ Debian 的 Docker Engine 与 x86_64(或 amd64)、armhf、arm64 和 ppc64le
|
||||
- `docker-doc`
|
||||
- `podman-docker`
|
||||
|
||||
此外,Docker Engine 依赖于`containerd`和`runc`。Docker Engine 将这些依赖项捆绑为一个包:`containerd.io`。如果您之前安装了`containerd`或`runc`,请卸载它们以避免与 Docker Engine 捆绑的版本冲突。
|
||||
此外,Docker Engine 依赖于`containerd`和`runc`。Docker Engine 将这些依赖项捆绑为一个包:`containerd.io`。如果你之前安装了`containerd`或`runc`,请卸载它们以避免与 Docker Engine 捆绑的版本冲突。
|
||||
|
||||
运行以下命令来卸载所有冲突的包:
|
||||
|
||||
@ -43,8 +43,193 @@ Debian 的 Docker Engine 与 x86_64(或 amd64)、armhf、arm64 和 ppc64le
|
||||
for pkg in docker.io docker-doc docker-compose podman-docker containerd runc; do sudo apt-get remove $pkg; done
|
||||
```
|
||||
|
||||
`apt-get`可能会报告您没有安装这些包。
|
||||
`apt-get`可能会报告你没有安装这些包。
|
||||
|
||||
卸载 Docker 时,不会自动删除存储在中的图像、容器、卷和网络`/var/lib/docker/`。如果您想从全新安装开始,并且希望清理所有现有数据,请阅读 [卸载 Docker Engine](#卸载DockerEngine)部分。
|
||||
卸载 Docker 时,不会自动删除存储在中的图像、容器、卷和网络`/var/lib/docker/`。如果你想从全新安装开始,并且希望清理所有现有数据,请阅读 [卸载 Docker Engine](#卸载DockerEngine)部分。
|
||||
|
||||
## 安装方法
|
||||
## 安装方法
|
||||
|
||||
你可以通过多种方式安装 Docker 引擎,具体取决于你的需求:
|
||||
|
||||
- Docker Engine 与 [Docker Desktop for Linux](https://docs.docker.com/desktop/setup/install/linux/) 是捆绑在一起的。这是最简单、最快捷的入门方式。
|
||||
- 从 [Docker 的 apt 仓库](https://docs.docker.com/engine/install/debian/#install-using-the-repository)中设置并安装 Docker 引擎。
|
||||
- [手动安装](https://docs.docker.com/engine/install/debian/#install-from-a-package)并手动管理升级。
|
||||
- 使用[简易脚本](https://docs.docker.com/engine/install/debian/#install-using-the-convenience-script)。仅推荐用于测试和开发环境。
|
||||
|
||||
### 使用 apt 仓库进行安装
|
||||
在新主机上首次安装 Docker Engine 之前,需要设置 Docker `apt`存储库。之后,你可以从存储库安装和更新 Docker。
|
||||
|
||||
1. 设置 Docker 的`apt`存储库。
|
||||
```bash
|
||||
# Add Docker's official GPG key:
|
||||
sudo apt-get update
|
||||
sudo apt-get install ca-certificates curl
|
||||
sudo install -m 0755 -d /etc/apt/keyrings
|
||||
sudo curl -fsSL https://download.docker.com/linux/debian/gpg -o /etc/apt/keyrings/docker.asc
|
||||
sudo chmod a+r /etc/apt/keyrings/docker.asc
|
||||
|
||||
# Add the repository to Apt sources:
|
||||
echo \
|
||||
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/debian \
|
||||
$(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
|
||||
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
|
||||
sudo apt-get update
|
||||
```
|
||||
:::info 笔记
|
||||
如果你使用衍生发行版,例如 Kali Linux,你可能需要替换此命令中预期打印版本代号的部分:
|
||||
```bash
|
||||
$(. /etc/os-release && echo "$VERSION_CODENAME")
|
||||
```
|
||||
将这部分替换为相应 Debian 版本的代号,例如`bookworm` 。
|
||||
:::
|
||||
2. 安装 Docker 软件包。
|
||||
:::code-group
|
||||
``` bash [最新的]
|
||||
# 安装 Docker 软件包。
|
||||
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
|
||||
```
|
||||
```bash [具体版本]
|
||||
# 要安装特定版本的 Docker Engine,请首先列出存储库中的可用版本:
|
||||
# List the available versions:
|
||||
apt-cache madison docker-ce | awk '{ print $3 }'
|
||||
|
||||
5:27.4.0-1~debian.12~bookworm
|
||||
5:27.3.1-1~debian.12~bookworm
|
||||
...
|
||||
|
||||
# 或
|
||||
|
||||
# 选择所需的版本并安装:
|
||||
VERSION_STRING=5:27.4.0-1~debian.12~bookworm
|
||||
sudo apt-get install docker-ce=$VERSION_STRING docker-ce-cli=$VERSION_STRING containerd.io docker-buildx-plugin docker-compose-plugin
|
||||
```
|
||||
:::
|
||||
|
||||
3. 通过运行`hello-world`映像验证安装是否成功:
|
||||
```bash
|
||||
sudo docker run hello-world
|
||||
```
|
||||
此命令下载测试映像并在容器中运行它。当容器运行时,它会打印一条确认消息并退出。
|
||||
|
||||
你现在已经成功安装并启动了 Docker Engine。
|
||||
:::tip 提示
|
||||
尝试在没有 root 的情况下运行时收到错误?
|
||||
`docker`用户组存在但不包含任何用户,这就是为什么你需要使用`sudo`来运行 Docker 命令。继续 [Linux 安装后](https://docs.docker.com/engine/install/linux-postinstall) 允许非特权用户运行 Docker 命令以及其他可选配置步骤。
|
||||
:::
|
||||
|
||||
#### 升级 Docker 引擎
|
||||
要升级 Docker Engine,请按照以上步骤 2 进行操作: [安装说明](#安装方法),选择你要安装的新版本。
|
||||
|
||||
### 从包安装
|
||||
如果你无法使用 Docker 的`apt`存储库来安装 Docker Engine,你可以下载适合你的版本的`deb`文件并手动安装。每次升级 Docker Engine 时都需要下载新文件。
|
||||
|
||||
1. 前往 [https://download.docker.com/linux/debian/dists/](https://download.docker.com/linux/debian/dists/).
|
||||
2. 在列表中选择你的 Debian 版本。
|
||||
3. 转到`pool/stable`/并选择适用的架构( `amd64` 、 `armhf` 、 `arm64`或`s390x` )。
|
||||
4. 下载 Docker 引擎、CLI、containerd 和 Docker Compose 软件包的以下`deb`文件:
|
||||
- `containerd.io_<version>_<arch>.deb`
|
||||
- `docker-ce_<version>_<arch>.deb`
|
||||
- `docker-ce-cli_<version>_<arch>.deb`
|
||||
- `docker-buildx-plugin_<version>_<arch>.deb`
|
||||
- `docker-compose-plugin_<version>_<arch>.deb`
|
||||
5. 安装`.deb`软件包。将以下示例中的路径更新为下载 Docker 软件包的位置。
|
||||
```bash
|
||||
sudo dpkg -i ./containerd.io_<version>_<arch>.deb \
|
||||
./docker-ce_<version>_<arch>.deb \
|
||||
./docker-ce-cli_<version>_<arch>.deb \
|
||||
./docker-buildx-plugin_<version>_<arch>.deb \
|
||||
./docker-compose-plugin_<version>_<arch>.deb
|
||||
```
|
||||
Docker 守护进程自动启动。
|
||||
6. 通过运行`hello-world`映像验证安装是否成功:
|
||||
```bash
|
||||
sudo service docker start
|
||||
sudo docker run hello-world
|
||||
```
|
||||
此命令下载测试映像并在容器中运行它。当容器运行时,它会打印一条确认消息并退出。
|
||||
|
||||
你现在已经成功安装并启动了 Docker Engine。
|
||||
|
||||
:::tip 提示
|
||||
尝试在没有 root 的情况下运行时收到错误?
|
||||
|
||||
docker用户组存在但不包含任何用户,这就是为什么你需要使用sudo来运行 Docker 命令。继续 [Linux 安装后](https://docs.docker.com/engine/install/linux-postinstall) 允许非特权用户运行 Docker 命令以及其他可选配置步骤。
|
||||
:::
|
||||
|
||||
#### 升级 Docker 引擎
|
||||
要升级 Docker Engine,请下载较新的软件包文件并重复 [安装过程](#从包安装),指向新文件。
|
||||
|
||||
### 使用便捷脚本安装
|
||||
Docker 提供了一个方便的脚本,位于 [https://get.docker.com/](https://get.docker.com/)将 Docker 安装到 非交互的开发环境。便利脚本不是 推荐用于生产环境,但它对于创建 根据你的需求定制配置脚本。另请参阅 [使用存储库安装](https://docs.docker.com/engine/install/debian/#install-using-the-repository)步骤学习 有关使用包存储库进行安装的安装步骤。源代码 因为该脚本是开源的,你可以在 [GitHub 上的`docker-install`存储库](https://github.com/docker/docker-install)。
|
||||
|
||||
在本地运行脚本之前,请务必先检查从互联网下载的脚本。安装之前,请熟悉便利脚本的潜在风险和限制:
|
||||
- 该脚本需要`root`或`sudo`权限才能运行。
|
||||
- 该脚本尝试检测你的 Linux 发行版和版本,并为你配置包管理系统。
|
||||
- 该脚本不允许你自定义大多数安装参数。
|
||||
- 该脚本会安装依赖项和建议,而不要求确认。这可能会安装大量软件包,具体取决于主机的当前配置。
|
||||
- 默认情况下,该脚本会安装最新稳定版本的 Docker、containerd 和 runc。使用此脚本配置计算机时,可能会导致 Docker 主要版本意外升级。在部署到生产系统之前,始终在测试环境中测试升级。
|
||||
- 该脚本并非旨在升级现有的 Docker 安装。使用脚本更新现有安装时,依赖项可能无法更新到预期版本,从而导致版本过时。
|
||||
:::tip 提示
|
||||
运行前预览脚本步骤。你可以使用`--dry-run`选项运行脚本来了解脚本在调用时将运行哪些步骤:
|
||||
```bash
|
||||
curl -fsSL https://get.docker.com -o get-docker.sh
|
||||
sudo sh ./get-docker.sh --dry-run
|
||||
```
|
||||
:::
|
||||
|
||||
此示例从以下位置下载脚本 [https://get.docker.com/](https://get.docker.com/)并运行它以在 Linux 上安装 Docker 的最新稳定版本:
|
||||
```bash
|
||||
curl -fsSL https://get.docker.com -o get-docker.sh
|
||||
sudo sh get-docker.sh
|
||||
Executing docker install script, commit: 7cae5f8b0decc17d6571f9f52eb840fbc13b2737
|
||||
<...>
|
||||
```
|
||||
|
||||
你现在已经成功安装并启动了 Docker Engine。 `docker` 服务在基于 Debian 的发行版上自动启动。
|
||||
在基于`RPM`的发行版上,例如 CentOS、Fedora、RHEL 或 SLES,你需要使用适当的`systemctl`或`service`命令手动启动它。
|
||||
正如消息所示,默认情况下非 root 用户无法运行 Docker 命令。
|
||||
|
||||
|
||||
:::info 以非特权用户身份使用 Docker,还是以无根模式安装?
|
||||
安装脚本需要`roo`t或`sudo`权限才能安装 使用 Docker。
|
||||
如果你想授予非root用户访问Docker的权限,请参阅 [Linux 的安装后步骤](https://docs.docker.com/engine/install/linux-postinstall/#manage-docker-as-a-non-root-user)。
|
||||
你还可以在没有`root`权限的情况下安装 Docker,或者配置为运行在 无根模式。
|
||||
有关以无根模式运行 Docker 的说明,请参阅 [以非 root 用户身份运行 Docker 守护进程(无 root 模式)](https://docs.docker.com/engine/security/rootless/) 。
|
||||
:::
|
||||
|
||||
#### 安装预发行版
|
||||
Docker 还提供了一个方便的脚本: [https://test.docker.com/](https://test.docker.com/)在 Linux 上安装 Docker 的预发行版。
|
||||
此脚本与`get.docker.com`上的脚本相同,但将包管理器配置为使用 Docker 包存储库的测试通道。
|
||||
测试通道包括 Docker 的稳定版和预发行版(测试版、候选版)。
|
||||
使用此脚本可以尽早访问新版本,并在稳定版本发布之前在测试环境中对其进行评估。
|
||||
|
||||
要从测试通道在 Linux 上安装最新版本的 Docker,请运行:
|
||||
|
||||
```bash
|
||||
curl -fsSL https://test.docker.com -o test-docker.sh
|
||||
sudo sh test-docker.sh
|
||||
```
|
||||
|
||||
#### 使用便捷脚本后升级 Docker
|
||||
如果你使用便捷脚本安装了 Docker,则应直接使用包管理器升级 Docker。
|
||||
重新运行便利脚本没有任何好处。如果它尝试重新安装主机上已存在的存储库,重新运行它可能会导致问题。
|
||||
|
||||
## 卸载 Docker 引擎
|
||||
1. 卸载 Docker Engine、CLI、containerd 和 Docker Compose 软件包:
|
||||
```bash
|
||||
sudo apt-get purge docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-ce-rootless-extras
|
||||
```
|
||||
2. 主机上的映像、容器、卷或自定义配置文件不会自动删除。要删除所有映像、容器和卷:
|
||||
```bash
|
||||
sudo rm -rf /var/lib/docker
|
||||
sudo rm -rf /var/lib/containerd
|
||||
```
|
||||
3. 删除源列表和密钥环
|
||||
```bash
|
||||
sudo rm /etc/apt/sources.list.d/docker.list
|
||||
sudo rm /etc/apt/keyrings/docker.asc
|
||||
```
|
||||
你必须手动删除任何编辑的配置文件。
|
||||
|
||||
## 后续步骤
|
||||
继续 [Linux 的安装后步骤](https://docs.docker.com/engine/install/linux-postinstall/)。
|
50
docs/storage/index.md
Normal file
50
docs/storage/index.md
Normal file
@ -0,0 +1,50 @@
|
||||
---
|
||||
outline: [2,3]
|
||||
---
|
||||
# 存储
|
||||
|
||||
默认情况下,在容器内创建的所有文件都存储在位于只读、不可变图像层之上的可写容器层上。
|
||||
当容器被销毁时,写入容器层的数据不会保留。这意味着如果另一个进程需要数据,则可能很难从容器中获取数据。
|
||||
每个容器的可写层都是唯一的。您无法轻松地将数据从可写层提取到主机或另一个容器。
|
||||
|
||||
## 存储挂载选项
|
||||
Docker 支持以下类型的存储挂载,用于在容器的可写层之外存储数据:
|
||||
- [卷挂载](https://docs.docker.com/engine/storage/#volume-mounts)
|
||||
- [绑定挂载](https://docs.docker.com/engine/storage/#bind-mounts)
|
||||
- [tmpfs 挂载](https://docs.docker.com/engine/storage/#tmpfs-mounts)
|
||||
- [命名管道](https://docs.docker.com/engine/storage/#named-pipes)
|
||||
|
||||
无论您选择使用哪种类型的挂载,容器中的数据看起来都相同。它作为容器文件系统中的目录或单个文件公开。
|
||||
|
||||
### 卷挂载
|
||||
卷是由 Docker 守护程序管理的持久性存储机制。
|
||||
即使在使用它们的容器被删除后,它们也会保留数据。
|
||||
卷数据存储在主机上的文件系统上,但为了与卷中的数据进行交互,您必须将卷挂载到容器中。
|
||||
直接访问卷数据或与卷数据交互是不受支持的、未定义的行为,并且可能会导致卷或其数据以意外的方式中断。
|
||||
|
||||
卷非常适合性能关键型数据处理和长期存储需求。
|
||||
由于存储位置是在守护程序主机上管理的,因此卷提供与直接访问主机文件系统相同的原始文件性能。
|
||||
|
||||
### 绑定挂载
|
||||
绑定挂载在主机系统路径和容器之间创建直接链接,允许访问存储在主机上任何位置的文件或目录。
|
||||
由于它们未被 Docker 隔离,因此主机上的非 Docker 进程和容器进程都可以同时修改挂载的文件。
|
||||
|
||||
当您需要能够从容器和主机访问文件时,请使用 bind 挂载。
|
||||
|
||||
### TMPFS 挂载
|
||||
tmpfs 挂载将文件直接存储在主机的内存中,确保数据不会写入磁盘。
|
||||
这种存储是短暂的:当容器停止或重新启动,或者当主机重新启动时,数据会丢失。
|
||||
tmpfs 挂载不会将数据保留在 Docker 主机上或容器的文件系统中。
|
||||
|
||||
这些挂载适用于需要临时内存存储的场景,例如缓存中间数据、处理敏感信息(如凭证)或减少磁盘 I/O。
|
||||
仅当数据不需要在当前容器会话之外保留时,才使用 tmpfs 挂载。
|
||||
|
||||
### 命名管道
|
||||
[命名管道](https://docs.microsoft.com/en-us/windows/desktop/ipc/named-pipes) 可用于 Docker 主机和容器之间的通信。
|
||||
常见 用例是在容器内运行第三方工具并连接到 使用命名管道的 Docker 引擎 API。
|
||||
|
||||
## 后续步骤
|
||||
- 进一步了解 [卷](https://docs.docker.com/engine/storage/volumes/)。
|
||||
- 进一步了解 [绑定挂载](https://docs.docker.com/engine/storage/bind-mounts/)。
|
||||
- 进一步了解 [tmpfs 挂载](https://docs.docker.com/engine/storage/tmpfs/)。
|
||||
- 进一步了解 [存储驱动程序](https://docs.docker.com/engine/storage/drivers/),它们与 BIND 挂载或卷无关,但允许您将数据存储在容器的可写层中。
|
1
docs/storage/volume.md
Normal file
1
docs/storage/volume.md
Normal file
@ -0,0 +1 @@
|
||||
# 卷
|
Loading…
Reference in New Issue
Block a user