diff --git a/notes/Docker_基础.md b/notes/Docker_基础.md
index df529d1..6a3d8bb 100644
--- a/notes/Docker_基础.md
+++ b/notes/Docker_基础.md
@@ -14,19 +14,17 @@ Docker 是一个构建,发布和运行应用程序的开放平台。Docker 以
Docker 使用 Go 语言进行开发,基于 Linux 内核的 cgroup,namespace,以及 AUFS 类的 Union FS 等技术,对进程进行封装隔离,属于操作系统层面的虚拟化技术。最初实现是基于 LXC,从 0.7 版本以后开始去除 LXC,转而使用自行开发的 libcontainer,从 1.11 开始,则进一步演进为使用 runC 和 containerd。
-- runc :是一个 Linux 命令行工具,用于根据 [OCI容器运行时规范](https://github.com/opencontainers/runtime-spec) 创建和运行容器。
-- containerd :是一个守护程序,它管理容器生命周期,提供了在一个节点上执行容器和管理镜像的最小功能集。
+- **runc** :是一个 Linux 命令行工具,用于根据 [OCI容器运行时规范](https://github.com/opencontainers/runtime-spec) 创建和运行容器。
+- **containerd** :是一个守护程序,它管理容器生命周期,提供了在一个节点上执行容器和管理镜像的最小功能集。
下图体现了 Docker 和传统虚拟化方式的不同之处:传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,再在该系统上运行所需应用进程;而 Docker 容器内的应用进程则是直接运行于宿主的内核,容器内没有自己的内核,而且也没有进行硬件虚拟,因此要比传统虚拟机更为轻便。
-
## 二、Docker 架构与核心概念
Docker 使用 client-server 架构, Docker 客户端将命令发送给 Docker 守护进程,后者负责构建,运行和分发 Docker 容器。 Docker客户端和守护程序使用 REST API,通过 UNIX 套接字或网络接口进行通信。核心概念如下:
-
### 2.1 镜像
Docker 镜像(Image)是一个特殊的文件系统,包含了程序运行时候所需要的资源和环境。镜像不包含任何动态数据,其内容在构建之后也不会被改变。
@@ -62,7 +60,6 @@ Docker 客户端(docker)是用户与 Docker 交互的主要方式。当你
Docker 提供了大量命令用于管理镜像、容器和服务,命令的统一使用格式为:` docker [OPTIONS] COMMAND` ,其中 OPTIONS 代表可选参数。需要注意的是 Docker 命令的执行一般都需要获取 root 权限,这是因为 Docker 的命令行工具 docker 与 docker daemon 是同一个二进制文件,docker daemon 负责接收并执行来自 docker 的命令,它的运行需要 root 权限。所有常用命令及其使用场景如下:
-
### 3.1 基础命令
- **docker version**:用于查看 docker 的版本信息
@@ -79,10 +76,10 @@ Docker 提供了大量命令用于管理镜像、容器和服务,命令的统
列出所有顶层镜像的相关信息。常用参数如下:
-- -a :显示所有镜像,包括中间隐藏的镜像
-- -q :只显示镜像 ID
-- --digests :显示摘要信息
-- --no-trunc :显示完整镜像信息
+- **-a** :显示所有镜像,包括中间隐藏的镜像
+- **-q** :只显示镜像 ID
+- **--digests** :显示摘要信息
+- **--no-trunc** :显示完整镜像信息
#### 3. docker pull 镜像名 [:TAG]
@@ -98,23 +95,23 @@ Docker 提供了大量命令用于管理镜像、容器和服务,命令的统
run 是 docker 中最为核心的一个命令,用于新建并启动容器,其拥有众多可用参数,可以使用`docker run --help`查看所有可用参数。常用参数如下:
-+ -i :表示使用交互模式,始终保持输入流开放;
-+ -t :表示分配一个伪终端,通常和`-i`结合使用,表示使用伪终端与容器进行交互;
-+ -d :以后台方式运行容器;
-+ --name :指定容器启动容器的名字,如果不指定,则由 docker 随机分配;
-+ -c :用于给运行在容器中的所有进程分配 CPU 的 shares 值,这是一个相对权重,实际的处理速度与宿主机的 CPU 相关;
-+ -m :用于限制为容器中所有进程分配的内存总量,以B、K、M、G为单位;
-+ -v :用于挂载数据卷 volume,可以用多个`-v`参数同时挂载多个 volume。volume 的格式为:`[host-dir]:[container-dir]:[rw:ro]`,`[rw:ro]`用于指定数据卷的模式,`rw`代表读写模式,`ro`代表只读模式。
-+ -p :用于将容器的端口暴露给宿主机的端口,格式为:`hostPort:containerPort`,通过端口的暴露,可以让外部主机能够访问容器内的应用。
++ **-i** :表示使用交互模式,始终保持输入流开放;
++ **-t** :表示分配一个伪终端,通常和`-i`结合使用,表示使用伪终端与容器进行交互;
++ **-d** :以后台方式运行容器;
++ **--name** :指定容器启动容器的名字,如果不指定,则由 docker 随机分配;
++ **-c** :用于给运行在容器中的所有进程分配 CPU 的 shares 值,这是一个相对权重,实际的处理速度与宿主机的 CPU 相关;
++ **-m** :用于限制为容器中所有进程分配的内存总量,以B、K、M、G为单位;
++ **-v** :用于挂载数据卷 volume,可以用多个`-v`参数同时挂载多个 volume。volume 的格式为:`[host-dir]:[container-dir]:[rw:ro]`,`[rw:ro]`用于指定数据卷的模式,`rw`代表读写模式,`ro`代表只读模式。
++ **-p** :用于将容器的端口暴露给宿主机的端口,格式为:`hostPort:containerPort`,通过端口的暴露,可以让外部主机能够访问容器内的应用。
#### 2. docker ps [OPTIONS]
列出当前所有正在运行的容器。常用参数如下:
-- -a :列出所有容器,包括运行的和已经停止的所有容器
-- -n :显示最近创建的 n 个容器
-- -q :只显示容器编号
-- --no-trunc :不要截断输出信息
+- **-a** :列出所有容器,包括运行的和已经停止的所有容器
+- **-n** :显示最近创建的 n 个容器
+- **-q** :只显示容器编号
+- **--no-trunc** :不要截断输出信息
#### 3. 启动\重启\停止\强制停止容器
@@ -131,8 +128,8 @@ run 是 docker 中最为核心的一个命令,用于新建并启动容器,
想要退出正在运行的容器,有以下两种常用方法:
-+ exit :退出并停止容器;
-+ ctrl+P+Q :退出。
++ **exit** :退出并停止容器;
++ **ctrl+P+Q** :退出。
#### 6. docker rm 容器名或ID
@@ -150,12 +147,12 @@ docker inspect --format='{{.NetworkSettings}}' 32cb3ace3279
可以使用`docker logs [OPTIONS] CONTAINER`查看容器中进程的运行日志,常用参数如下:
-- --details :显示日志详情
-- -f :跟随日志输出显示
-- --tail :从末尾开始显示指定行的数据
-- -t :显示时间戳
-- --since :开始时间
-- --until : 结束时间
+- **--details** :显示日志详情
+- **-f** :跟随日志输出显示
+- **--tail** :从末尾开始显示指定行的数据
+- **-t** :显示时间戳
+- **--since** :开始时间
+- **--until** : 结束时间
## 四、DockerFile
@@ -278,7 +275,6 @@ docker run -it -p 8080:8080 spring-boot-base-java
这里为了观察到启动效果,所以使用交互的方式启动,实际部署时可以使用`-d`参数来后台启动,输出如下:
-
### 5.2 基于 JDK 镜像部署 Spring Boot 项目
上面的项目我们是基于最基础的 Centos 镜像开始构建,但由于 Docker Hub 上已经提供了 JDK 的镜像,我们也可以选择从 JDK 镜像开始构建,此时构建过程更加简单。构建步骤和上面的完全一致,只是 Dockerfile 的内容有所不同,如下: