我们都知道Dockerfile是用来描述镜像文件的,其中包含一系列命令和指令,通过Docker构建后得到了镜像Image,运行镜像Image后就是我们熟悉的容器Container,那么Dockfile怎么编写呢?下面是一个基本的Dockerfile示例:
# 基础镜像
FROM ubuntu:latest
# 作者信息
LABEL maintainer="your name <youremail@example.com>"
# 安装依赖
RUN apt-get update && apt-get install -y curl git python
# 复制文件
COPY . /app
# 工作目录
WORKDIR /app
# 运行命令
CMD [ "python", "./app.py" ]
更详细写法请前往:https://docs.docker.com/engine/reference/builder/
该Dockerfile将使用最新版本的Ubuntu作为基础镜像,并安装一些依赖包。然后,它将复制当前目录中的文件到容器的/app目录下,并将工作目录设置为/app。最后,它将在容器启动时运行python ./app.py命令。
Docker的官方仓库DockerHub提供了很多制作好的镜像,一般来说基础镜像是Docker镜像构建的起点,即构建一个新的Docker镜像时,通常需要先选择一个已有的基础镜像作为起点,因为它包含了一组已安装好的操作系统、软件和应用程序等组件,可以理解为是一个“打包好”的操作系统和应用环境。通过在基础镜像上添加应用程序和配置,最终可以得到一个新的完整应用镜像。
Docker也可以将一个空镜像作为构建的起点,一般使用空镜像可以打包出最小的Docker镜像,如:
# 空镜像
FROM scratch
注意:基础镜像的选择应该根据实际需求和使用场景来决定。
在编写好Dockerfile后,使用命令行进入到该目录中,使用以下命令构建镜像:
# -t 参数指定要创建的镜像的名称,
# . 表示当前目录是构建上下文。
docker build -t <镜像名称> .
Docker会按照Dockerfile中定义的步骤信息进行构建镜像,一般来说构建过程需要一些时间,具体取决于镜像大小、依赖安装包等。
构建完成后,我们就可以查看所有的镜像列表:
# 查看所有的镜像列表
docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
demo/demo latest a7d37dd51548 37 hours ago 461MB
此时我们已经通过Dockerfile构建出了镜像,要想运行镜像还需要执行:
# 运行镜像
docker run <镜像名称>
如果该镜像启动成功,将会在终端中输出运行的应用程序的信息,此时容器就启动了,如果想查看运行的容器的列表,可以执行以下命令:
# 查看所有运行的容器列表
docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f516b5ee2533 demo/demo "/usr/bin/tini -- /u…" 51 seconds ago Up 50 seconds 8080/tcp, 50000/tcp charming_thompson
如果想要进入到容器中,可以执行以下命令:
# exec 表示在一个运行的容器中执行命令
# <CONTAINER ID> 就是从 docker ps 命令中得到的容器id
# /bin/sh 就是要执行的容器命令,表示进入到容器终端
docker exec -it <CONTAINER ID> /bin/sh