Docker是一种开源的容器化平台,用于构建、部署和运行应用程序。它通过使用容器来实现应用程序的隔离和封装,使得应用程序可以在不同的计算环境中以一致的方式运行。
容器是一种轻量级的虚拟化技术,它可以将应用程序及其所有依赖项打包到一个独立的、可移植的容器中。这个容器包含了应用程序所需的所有文件、库、环境变量和配置信息。与传统的虚拟机不同,容器不需要运行完整的操作系统,而是共享主机操作系统的内核,因此它们更加轻量级和高效。
Docker提供了一个简单而强大的命令行工具和API,使得用户可以轻松地创建、启动、停止和管理容器。它还提供了一个容器镜像的机制,允许用户将容器打包成可重复部署的组件。这些容器镜像可以通过Docker Hub等容器注册中心进行共享和分发,从而加速开发和部署过程。
要使用Docker Hub上别人的镜像,可以按照以下步骤进行操作:
docker search
命令在命令行中进行搜索。docker pull
命令下载所需的镜像。docker run
命令来创建并运行一个容器实例。指定下载的镜像名称和其他必要的选项。docker run
命令选项来配置容器。docker run
:docker run
命令用于创建并运行一个新的Docker容器。它的主要作用是在容器中启动一个新的应用程序实例。当你运行docker run
命令时,Docker会执行以下操作:
例如,以下命令将创建一个名为my-container
的新容器,并在其中运行my-image
镜像的默认命令:
docker run --name my-container my-image
使用docker exec
命令,你可以在运行中的Docker容器内部执行任意的命令。
当你运行docker exec
命令时,Docker会执行以下操作:
-it
选项)或后台模式(默认)运行命令。如果你有一个名为my-container
的容器,并且想要在其中执行ls
命令来列出容器内的文件和目录,你可以运行以下命令:
docker exec my-container ls
你还可以使用-it
选项以交互模式运行命令,就像在终端中一样。例如:
docker exec -it my-container bash
这将在my-container
容器内部启动一个交互式的Bash会话。
我要用hexo来部署博客,但是我懒得配置环境,那么我就可以选择Docker免去安装环节。
docker pull spurin/hexo
https://hub.docker.com/r/spurin/hexo
这是一个别人已经发布的docker image,我把它拉下来。
使用docker create
命令创建Docker容器:
docker create --name=hexo-blog\
-e HEXO_SERVER_PORT=4000 \
-e GIT_USER="Your Name" \
-e GIT_EMAIL="[email protected]" \
-v /blog/domain.com:/app \
-p 4000:4000 \
spurin/hex
其中,
--name=hexo-blog
:通过--name
选项指定了容器的名称。容器名称用于唯一标识容器实例。
-p 4000:4000
:通过-p
选项将主机的端口4000
映射到容器的端口4000
。这样,可以通过主机的4000
端口访问容器内运行的应用程序。
-v /blog/domain.com:/app
:通过-v
选项将主机上的目录/blog/domain.com
挂载到容器内的/app
目录。这意味着主机上的/blog/domain.com
目录中的文件将在容器内的/app
目录中可见和可访问。
-e HEXO_SERVER_PORT=4000
:通过-e
选项设置了环境变量HEXO_SERVER_PORT
的值为4000
。这个环境变量能在容器内的应用程序中使用。
Docker,启动!!!!:
docker start hexo-blog
可以看到启动后的docker里面有了个linux一样的目录,app目录下把本地的文件夹挂载进了容器里面。
可以通过docker正常使用hexo了。
进入
docker exec -it hexo-blog bash
生成
docker exec -it hexo-blog hexo g
docker exec
:这是Docker命令的一部分,用于在运行中的容器内部执行命令。-it
:这是docker exec
命令的选项之一,用于以交互模式运行命令并分配一个伪终端(pseudo-TTY)。这使得在容器内部执行命令时可以进行交互式的输入和输出。hexo-blog
:这是容器的名称或容器ID。通过指定容器名称或ID,docker exec
命令可以确定要在哪个容器内部执行命令。hexo g
:这是要在容器内部执行的命令。在这个例子中,hexo g
是一个命令行命令,它将在容器内部运行Hexo命令行工具的generate
命令(简写为g
)。这个命令用于生成静态网站内容。docker images
:列出本地所有的镜像。docker pull <镜像名>
:从容器注册中心(如Docker Hub)下载指定的镜像。docker push <镜像名>
:将本地的镜像推送到容器注册中心。docker rmi <镜像名>
:删除指定的镜像。docker ps
:列出当前正在运行的容器。docker ps -a
:列出所有的容器,包括停止运行的容器。docker run <镜像名>
:创建并运行一个新容器。docker start <容器ID或名称>
:启动一个已经创建的容器。docker stop <容器ID或名称>
:停止一个正在运行的容器。docker rm <容器ID或名称>
:删除一个已经停止的容器。docker exec -it <容器ID或名称> <命令>
:在运行的容器中执行指定命令。docker logs <容器ID或名称>
:查看容器的日志输出。docker inspect <容器ID或名称>
:查看容器的详细信息,包括IP地址、端口映射等。docker stats
:实时显示运行容器的资源使用情况。docker build -t <镜像名>
:根据Dockerfile构建一个新的镜像。docker tag <现有镜像名> <新镜像名>
:为现有镜像添加一个标签。docker commit <容器ID或名称> <新镜像名>
:根据容器创建一个新的镜像。可以使用docker --help
命令查看完整的Docker命令列表和帮助信息。
构建Docker镜像的主要步骤是编写一个称为Dockerfile的文本文件,并使用Docker命令来执行构建过程。
下面是一个简单的Docker镜像构建的示例流程:
Dockerfile
的文本文件。Dockerfile
文件,并按照以下格式编写构建指令:# 基础镜像
FROM <基础镜像>
# 设置工作目录
WORKDIR /app
# 复制应用程序文件到容器中
COPY <本地文件路径> <容器目标路径>
# 安装应用程序依赖
RUN <命令>
# 暴露容器端口
EXPOSE <端口号>
# 定义容器启动时执行的命令
CMD <命令>
在上述Dockerfile
中,你需要替换以下内容:
<基础镜像>
:选择适合你应用程序的基础镜像,例如ubuntu:latest
或node:14
。<本地文件路径>
:指定本地应用程序文件的路径。这可以是单个文件或整个目录。<容器目标路径>
:指定将文件复制到容器中的目标路径。<命令>
:在构建过程中需要执行的命令,例如安装软件包、运行脚本等。<端口号>
:将容器内的端口映射到主机上的端口,以便访问应用程序。Dockerfile
文件。cd
命令切换到包含Dockerfile
的目录。docker build -t <镜像名> .
在上述命令中,你需要替换<镜像名>
为你想要给镜像命名的名称,可以是任何合法的名称。.
表示构建上下文的路径,这里指的是当前目录。
Dockerfile
中的指令执行构建过程,并下载所需的基础镜像、复制文件、执行命令等。构建过程可能需要一些时间,具体取决于镜像大小和指令复杂性。docker images
命令查看已构建的镜像列表,找到刚才构建的镜像。