diff --git a/02_basic_concept/2.3_repository.md b/02_basic_concept/2.3_repository.md
index 26ada70..6da2d77 100644
--- a/02_basic_concept/2.3_repository.md
+++ b/02_basic_concept/2.3_repository.md
@@ -16,25 +16,29 @@ Docker Registry 是镜像分发和管理的核心组件。本节将介绍 Regist
Docker Registry 中可以包含多个 Repository,每个 Repository 可以包含多个 Tag。如图 2-2 所示,它们之间具有清晰的层级关系。
-```
-┌─────────────────────────────────────────────────────────────────────┐
-│ Docker Registry │
-│ (如 Docker Hub) │
-│ ┌─────────────────────────────────────────────────────────────┐ │
-│ │ Repository(仓库): nginx │ │
-│ │ ┌─────────┐ ┌─────────┐ ┌─────────┐ ┌─────────┐ │ │
-│ │ │ :latest │ │ :1.25 │ │ :1.24 │ │ :alpine │ ... │ │
-│ │ │ (tag) │ │ (tag) │ │ (tag) │ │ (tag) │ │ │
-│ │ └─────────┘ └─────────┘ └─────────┘ └─────────┘ │ │
-│ └─────────────────────────────────────────────────────────────┘ │
-│ │
-│ ┌─────────────────────────────────────────────────────────────┐ │
-│ │ Repository(仓库): mysql │ │
-│ │ ┌─────────┐ ┌─────────┐ ┌─────────┐ │ │
-│ │ │ :latest │ │ :8.0 │ │ :5.7 │ ... │ │
-│ │ └─────────┘ └─────────┘ └─────────┘ │ │
-│ └─────────────────────────────────────────────────────────────┘ │
-└─────────────────────────────────────────────────────────────────────┘
+```mermaid
+flowchart TB
+ subgraph Registry ["Docker Registry(如 Docker Hub)"]
+ direction TB
+ subgraph RepoNginx ["Repository(仓库): nginx"]
+ direction LR
+ N1(":latest (tag)")
+ N2(":1.25 (tag)")
+ N3(":1.24 (tag)")
+ N4(":alpine (tag)")
+ N5("...")
+ N1 ~~~ N2 ~~~ N3 ~~~ N4 ~~~ N5
+ end
+ subgraph RepoMysql ["Repository(仓库): mysql"]
+ direction LR
+ M1(":latest")
+ M2(":8.0")
+ M3(":5.7")
+ M4("...")
+ M1 ~~~ M2 ~~~ M3 ~~~ M4
+ end
+ RepoNginx ~~~ RepoMysql
+ end
```
图 2-2 Registry、Repository 与 Tag 的层级关系
diff --git a/04_image/4.1_pull.md b/04_image/4.1_pull.md
index 5ebfb53..9968eb1 100644
--- a/04_image/4.1_pull.md
+++ b/04_image/4.1_pull.md
@@ -91,16 +91,15 @@ docker.io/library/ubuntu:24.04
从输出可以看到,镜像是**分层下载**的:
-```
-┌─────────────────────────────────────────────────────────────┐
-│ ubuntu:24.04 镜像 │
-├─────────────────────────────────────────────────────────────┤
-│ 第3层 c8299583700a ───────► 已存在,跳过下载 │
-├─────────────────────────────────────────────────────────────┤
-│ 第2层 be13a9d27eb8 ───────► 下载中... 完成 │
-├─────────────────────────────────────────────────────────────┤
-│ 第1层 92dc2a97ff99 ───────► 下载中... 完成 │
-└─────────────────────────────────────────────────────────────┘
+```mermaid
+flowchart TD
+ subgraph Image ["ubuntu:24.04 镜像"]
+ direction TB
+ L3["第3层 c8299583700a
(已存在,跳过下载)"]
+ L2["第2层 be13a9d27eb8
(下载中... 完成)"]
+ L1["第1层 92dc2a97ff99
(下载中... 完成)"]
+ L3 --- L2 --- L1
+ end
```
如果本地已有相同的层,Docker 会跳过下载,节省带宽和时间。
diff --git a/04_image/4.3_rm.md b/04_image/4.3_rm.md
index 9cb88ee..06350aa 100644
--- a/04_image/4.3_rm.md
+++ b/04_image/4.3_rm.md
@@ -96,25 +96,26 @@ Deleted: sha256:32770d1dcf835f192cafd6b9263b7b597a1778a403a109e2cc2ee866f74adf23
Docker 会检测镜像是否有容器依赖或其他标签指向,只有在确认为无用资源时才会真正删除存储层。
-```
-docker rmi redis:alpine
- │
- ▼
-┌───────────────────────────────────────────────────────────────┐
-│ 1. Untag:移除 redis:alpine 标签 │
-│ ↓ │
-│ 2. 检查是否还有其他标签指向这个镜像 │
-│ ├── 有 → 只 Untag,不删除 │
-│ └── 无 → │
-│ ↓ │
-│ 3. 检查是否有容器依赖 │
-│ ├── 有 → 报错,无法删除 │
-│ └── 无 → │
-│ ↓ │
-│ 4. 从上到下逐层删除,检查每层是否被其他镜像使用 │
-│ ├── 被使用 → 保留 │
-│ └── 未使用 → Deleted │
-└───────────────────────────────────────────────────────────────┘
+```mermaid
+flowchart TD
+ Start(["docker rmi redis:alpine"]) --> Step1
+
+ subgraph Process ["删除流程"]
+ direction TB
+ Step1["1. Untag:移除 redis:alpine 标签"] --> Step2
+
+ Step2{"2. 检查是否还有其他标签指向此镜像"}
+ Step2 -- "有" --> Keep1["只 Untag,不删除"]
+ Step2 -- "无" --> Step3
+
+ Step3{"3. 检查是否有容器依赖"}
+ Step3 -- "有" --> Error["报错,无法删除"]
+ Step3 -- "无" --> Step4
+
+ Step4{"4. 从上到下逐层删除,检查每层是否被其他镜像使用"}
+ Step4 -- "被使用" --> Keep2["保留该层"]
+ Step4 -- "未使用" --> Delete["Deleted (删除该层)"]
+ end
```
---
diff --git a/04_image/4.7_internal.md b/04_image/4.7_internal.md
index 4856a9a..c8efa73 100644
--- a/04_image/4.7_internal.md
+++ b/04_image/4.7_internal.md
@@ -25,16 +25,18 @@ Docker 镜像并不是一个单纯的文件,而是由一组文件系统叠加
当容器启动时,Docker 会在镜像的最上层,添加一个新的**可写层(Writable Layer)**,通常被称为**容器层**。
-```
-┌──────────────────────────────────────────────┐
-│ 容器层 (可写, Writable Container Layer) │ <-- 所有的写操作都在这里
-├──────────────────────────────────────────────┤
-│ 镜像层 (只读, Read-only Image Layer) │
-├──────────────────────────────────────────────┤
-│ 镜像层 (只读, Read-only Image Layer) │
-├──────────────────────────────────────────────┤
-│ 基础镜像层 (只读, Base Image Layer) │
-└──────────────────────────────────────────────┘
+```mermaid
+flowchart TD
+ subgraph Container ["运行中的容器"]
+ direction TB
+ L4["容器层 (可写, Writable Container Layer)"]
+ L3["镜像层 (只读, Read-only Image Layer)"]
+ L2["镜像层 (只读, Read-only Image Layer)"]
+ L1["基础镜像层 (只读, Base Image Layer)"]
+
+ L4 --- L3 --- L2 --- L1
+ end
+ Note["所有的写操作都在容器层这里"] -.-> L4
```
* **读取文件**:当容器需要读取文件时,Docker 会从最上层(容器层)开始向下层(镜像层)寻找,直到找到该文件为止。
diff --git a/05_container/5.2_daemon.md b/05_container/5.2_daemon.md
index c88794e..4ad8206 100644
--- a/05_container/5.2_daemon.md
+++ b/05_container/5.2_daemon.md
@@ -59,13 +59,13 @@ $ docker run -d ubuntu:24.04
#### 核心原理:容器的生命周期与主进程绑定
-```
-┌─────────────────────────────────────────────────────────────────────┐
-│ Docker 容器的生命周期 = 容器内 PID 1 进程的生命周期 │
-│ │
-│ 主进程启动 → 容器运行 │
-│ 主进程退出 → 容器停止 │
-└─────────────────────────────────────────────────────────────────────┘
+```mermaid
+flowchart TD
+ subgraph Lifecycle ["Docker 容器的生命周期 = 容器内 PID 1 进程的生命周期"]
+ direction LR
+ Start["主进程启动"] --> Run["容器运行"]
+ Exit["主进程退出"] --> Stop["容器停止"]
+ end
```
当你运行 `docker run -d ubuntu:24.04` 时:
diff --git a/05_container/5.4_attach_exec.md b/05_container/5.4_attach_exec.md
index d98539f..664bb35 100644
--- a/05_container/5.4_attach_exec.md
+++ b/05_container/5.4_attach_exec.md
@@ -129,14 +129,15 @@ $ docker attach 容器名
`attach` 会附加到容器的**主进程**(PID 1)的标准输入输出:
-```
-┌─────────────────────────────────────────┐
-│ 容器 │
-│ ┌─────────────────────────────────┐ │
-│ │ PID 1: /bin/bash (主进程) │◄───┼─── docker attach 附加到这里
-│ │ └─ 你的输入直接发送到主进程 │ │
-│ └─────────────────────────────────┘ │
-└─────────────────────────────────────────┘
+```mermaid
+flowchart LR
+ subgraph Container ["容器"]
+ direction TB
+ subgraph Process ["主进程"]
+ P1["PID 1: /bin/bash
(你的输入直接发送到主进程)"]
+ end
+ end
+ Attach["docker attach"] -->|"附加到这里"| P1
```
#### docker attach 示例
diff --git a/SUMMARY.md b/SUMMARY.md
index cbb24ef..20a37c0 100644
--- a/SUMMARY.md
+++ b/SUMMARY.md
@@ -10,10 +10,12 @@
* [快速上手](01_introduction/1.1_quickstart.md)
* [什么是 Docker](01_introduction/1.2_what.md)
* [为什么要用 Docker](01_introduction/1.3_why.md)
+ * [本章小结](01_introduction/summary.md)
* [第二章 基本概念](02_basic_concept/README.md)
* [镜像](02_basic_concept/2.1_image.md)
* [容器](02_basic_concept/2.2_container.md)
* [仓库](02_basic_concept/2.3_repository.md)
+ * [本章小结](02_basic_concept/summary.md)
* [第三章 安装 Docker](03_install/README.md)
* [Ubuntu](03_install/3.1_ubuntu.md)
* [Debian](03_install/3.2_debian.md)
@@ -33,6 +35,7 @@
* [使用 Dockerfile 定制镜像](04_image/4.5_build.md)
* [其它制作镜像的方式](04_image/4.6_other.md)
* [实现原理](04_image/4.7_internal.md)
+ * [本章小结](04_image/summary.md)
* [第五章 操作容器](05_container/README.md)
* [启动](05_container/5.1_run.md)
* [守护态运行](05_container/5.2_daemon.md)
@@ -40,11 +43,13 @@
* [进入容器](05_container/5.4_attach_exec.md)
* [导出和导入](05_container/5.5_import_export.md)
* [删除](05_container/5.6_rm.md)
+ * [本章小结](05_container/summary.md)
* [第六章 访问仓库](06_repository/README.md)
* [Docker Hub](06_repository/6.1_dockerhub.md)
* [私有仓库](06_repository/6.2_registry.md)
* [私有仓库高级配置](06_repository/6.3_registry_auth.md)
* [Nexus 3](06_repository/6.4_nexus3_registry.md)
+ * [本章小结](06_repository/summary.md)
## 第二部分: 进阶篇
@@ -67,14 +72,17 @@
* [参考文档](07_dockerfile/7.16_references.md)
* [多阶段构建](07_dockerfile/7.17_multistage_builds.md)
* [实战多阶段构建 Laravel 镜像](07_dockerfile/7.18_multistage_builds_laravel.md)
+ * [本章小结](07_dockerfile/summary.md)
* [第八章 数据与网络管理](08_data_network/README.md)
* [数据管理](08_data_network/data/README.md)
* [数据卷](08_data_network/data/volume.md)
* [挂载主机目录](08_data_network/data/bind-mounts.md)
* [tmpfs 挂载](08_data_network/data/tmpfs.md)
+ * [本章小结](08_data_network/data/summary.md)
* [网络配置](08_data_network/network/README.md)
* [配置 DNS](08_data_network/network/dns.md)
* [外部访问容器](08_data_network/network/port_mapping.md)
+ * [本章小结](08_data_network/network/summary.md)
* [第九章 Docker Buildx](09_buildx/README.md)
* [BuildKit](09_buildx/9.1_buildkit.md)
* [使用 buildx 构建镜像](09_buildx/9.2_buildx.md)
@@ -144,6 +152,7 @@
* [联合文件系统](14_implementation/14.4_ufs.md)
* [容器格式](14_implementation/14.5_container_format.md)
* [网络](14_implementation/14.6_network.md)
+ * [本章小结](14_implementation/summary.md)
## 第四部分: 实战篇