本文主要针对docker各指令如何使用做讲解说明,对docker中涉及到的各概念则摄入较少,所以需要读者对docker有一定的理解
一、安装
官方文档地址提供各平台下载渠道及各项说明
二、image文件
- 是二进制文件,可以继承或被继承
- 包含应用程序及其依赖
- 是docker容器的模版文件,docker根据image文件才能生成docker容器
- 同一个image文件可以生成多个同时运行的docker容器实例
- 通用性,可以copy到其他机器上使用
- 推荐使用现成image进行再加工使用官方仓库 Docker Hub
相关指令
// 1、查看版本号
docker version
// 2、查看当前运行容器
docker ps
// 3、查看本级所有image文件
docker image ls
// 4、删除image文件
docker image rm [imageName]
// 5、拉去image文件
docker pull [Docker-Hub-imageName]
或者
docker image pull [...]
// 6、运行image文件
// 此命令有自动抓取功能,如果检查所运行image不存在,则自动去Docker Hub上拉取再运行
docker container run [imageName]
// 7、手动终止image
docker container kill [containID]
三、container文件
docker容器,基于镜像(image)生成,是镜像的单个运行实例,也就是说,基于同一镜像,会生成相同初始状态的容器,但生成的容器都独立存在。
相关命令
以下命令中的container
均可不写,换句话说,与容器相关的指令container
均可不写
// 1、列出本机正在运行的容器
docker container ls
// 2、列出本机所有容器,包括终止运行的容器
docker container ls -all
// 3、终止容器
docker container rm [containerID]
// 4、删除容器
// 终止运行的容器仍然会占据硬盘空间,可以删除释放
docker container rm [containerID]
// 5、新建容器
// 每运行一次,就会新建一个容器,同样的命令运行两次,就会生成两个一摸一样的容器文件。
docker container run
// 6、运行容器
// 如果希望重复使用容器可以使用
docker container start [containerID]
// 7、终止容器运行
docker container stop [containerID]// 自行执行收尾清理工作后再终止 发送SIGTERM信号再发送SKGKILL信号
或者
docker container kill [containerID] // 强制终止 发送SKGKILL信号
// 8、查看log输出
docker container logs [containerID]
// 9、copy容器文件到本地
docker container cp [containerID]:[/path/to/file]
// 10、链接容器
docker exec -it [containerID或name /bin/bash
// 11、查看容器hash
docker inspect <containerID> | grep Id
exec
:插入一条指令,使容器处理指定指令
四、制作Docker容器
- 编写Dockerfile文件
- 创建image文件
- 生成容器
- 发布image文件
1、编写Dockerfile文件
创建dockerignore文件
作用是忽略不需要被打包进入image中的路径文件,根目录创建.dockerignore
/**
eg.
过滤这三个路径信息
如果无需要过滤项,可不创建*/
.git
node_modules
others
创建Dockerfile文件
同样项目根目录下创建,并填写如下内容:
FROM node:8.4 // 该image文件继承官方的node image,:表示标签,此处标签是8.4,及8.4版本的node
COPY . /app // 将目录项的所有文件(除被过滤路径),都copy进image文件的/app目录
WORKDIR /app // 指定接下来的工作路径为/app
RUN npm install //在/app目录下,运行npm install命令安装依赖。注意,安装后所有的依赖都将打包进入image文件
EXPOSE 3000 // 将容器3000端口暴露出来,允许外部访问
CMD node demo.js // 容器启动之后自动执行该命令,被指定后,docker run命令就不能附加命令了,比如前文/bin/bash,否则会覆盖该命令
RUN
:image构建阶段执行,执行结果会被打包进入image文件;CMD
:容器启动后执行- 一个
Dockerfile
文件可以包含多个RUN
命令,但只能包含一个CMD
命令
2、创建image文件
有了Dockerfile文件后,就可以创建image文件了:
docker image build -t [custom-imageName] .
//或者
docker image build -t [custom-imageName]:0.0.1 .
// 查看
// 如果运行成功,可以被查看到
docker image ls
-t
指定image文件名字,后面可以用:
指定标签,如果不指定则默认lastest
⚠️
:千万不要忘记指令结尾的.
,否则执行失败
3、生成容器
docker container run
命令会从image文件生成容器
docker container run -p 8000:3000 -it [imageName] /bin/bash
或者
docker container run -p 8000:3000 -it [imageName]:0.0.1 /bin/bash
或者
docker run -d --name=[containerName] [imageName] /bin/bash
注:命令中的container
均可不写
-p
:容器的3000端口映射到本机的8000端口-it
:容器的shell映射到当前的shell,然后你在本机窗口输入的命令,就会传入容器imageName
:image文件名字(如果有标签则:引用,默认lastest)/bin/bash
:容器启动以后,内部第一个执行的命令。这里是启动bash,保证用户可以使用shell,如果Dockerfile指定CMD,则此处可不写,否则会覆盖CMD命令-d
: 后端运行(以避免因前端关掉shell而导致服务异常)run
:create
与start
命令的集合,意味创建并启动一个容器--name=[xxx]
:指定容器名字,默认则容器随机生成--rm
:如果容器停止,则自动被删除
4、发布image文件
hub.docker.com或hub.docker.com注册账户
// 1、执行登录命令:
docker login
// 2、接着,为本地image标注用户名和版本:
docker image tag [imageID] [dockerHub用户名]/[项目名]:[tag]
// 实例:
docker image tag b13757590ce8:0.0.1 yxr/koa-demo:0.0.1
// 3、发布image文件
docker image push [dockerHub用户名]/[项目名]:[tag]
// 4、登录官网查看