首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >工具系列 | Docker基本概念小结

工具系列 | Docker基本概念小结

作者头像
Tinywan
发布2020-02-11 18:05:27
7410
发布2020-02-11 18:05:27
举报
文章被收录于专栏:开源技术小栈开源技术小栈

▍什么是Docker?

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

▍什么服务模式?

C/S模式。Docker是一个客户端-服务端(c/s)的架构程序。docker是以客户端(client)和守护进程(server)来运行。

▍什么通信方式?

Unix的socket套接字,如:unix:///var/run/docker/sock(默认连接方式)

▍那几部分组成?

  • Docker Client客户端
  • Docker Daemon服务端(守护进程)
  • Docker Image 镜像
  • Docker Container 容器

▍什么是Docker 仓库(hub)?

仓库(Repository)是集中存放镜像的地方。目前 Docker 官方维护了一个公共仓库 dDocker Hub。大部分需求都可以通过在 Docker Hub 中直接下载镜像来实现。

▍什么镜像(image)?

可理解为一个面向Docker引擎的只读模板,包含了文件系统。如:一个镜像可以只包含一个完整的操作系统环境,也可以安装了其他的应用程序。通过版本管理和增量的文件系统,Docker提供了一套十分简单的机制来创建和更新现有的镜像。

▍如何构建镜像?

即创建一个镜像,它包含安装运行所需的环境、程序代码等。这个创建过程就是使用 Dockerfile 来完成的。默认是从 Docker Hub 公共镜像源下载。

Dockerfile 的作用是从无到有的构建镜像。它包含安装运行所需的环境、程序代码等。这个创建过程就是使用 Dockerfile 来完成的。Dockerfile 为 docker build 命令准备的,用于构建一个自定义的 image 镜像。

在docker-compose里也可以用来实时 build。docker-compose.yml 为 docker-compose 准备的脚本,可以同时管理多个镜像,多个镜像之间可以使用官方 image 、和自定义的 Dockerfile 构建的 image 混合编排容器以及各种网络端口定义、储存空间定义等。

如果 image 镜像是从 docker hub registry 拉取下来的,那么 Dockerfile 就不需要;如果镜像是需要 build 的,那就需要提供 Dockerfile .

Dockerfile 就是记录了一个镜像的制作过程。把脚本把安装过程全部记录下来,再次安装的时候,执行脚本就行了。只要有了 Dockerfile 脚本文件(shell脚本), 只需执行 docker build . 就能制作镜像,而且 Dockerfile 就是文本文件,修改也很方便。

▍容器是如何启动的?

容器最终运行起来是通过拉取构建好的镜像,通过一系列运行指令(如端口映射、外部数据挂载、环境变量等)来启动服务的。区别:

  • 针对单个容器,这可以通过 docker run 来运行。
  • 针对多个容器,这可以通过 docker-compose up 来运行。

▍如何运行多个容器?

而如果涉及多个容器的运行(如服务编排)就可以通过 docker-compose 来实现,它可以轻松的将多个容器作为 service 来运行(当然也可仅运行其中的某个),并且提供了 scale (服务扩容) 的功能。

docker-compose 是编排容器的。例如,你有一个php镜像,一个mysql镜像,一个nginx镜像。如果没有docker-compose,那么每次启动的时候,你需要敲各个容器的启动参数,环境变量,容器命名,指定不同容器的链接参数等等一系列的操作,相当繁琐。

而用了docker-composer之后,你就可以把这些命令一次性写在docker-composer.yml文件中,以后每次启动这一整个环境(含3个容器)的时候,你只要敲一个 docker-composer up 命令就可以了

docker-compose 是解决项目需要哪些镜像、每个镜像怎么配置、要挂载哪些 volume、映射哪些端口 等等信息,都包含在 docker-compose.yml 里。

要启动服务,只需要 docker-compose up 就行,停止也只需要 docker-compse stop/down

▍Dockerfile与docker-compse.yml 文的区别?

  • Dockerfile 记录单个镜像的构建过程
  • docker-compse.yml 记录一个编排容器(多个镜像)的构建过程。
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-01-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Tinywan的杂货摊 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档