Docker的安装及使用

本文主要针对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而导致服务异常)
  • runcreatestart命令的集合,意味创建并启动一个容器
  • --name=[xxx]:指定容器名字,默认则容器随机生成
  • --rm:如果容器停止,则自动被删除

4、发布image文件

hub.docker.comhub.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、登录官网查看
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。