要了解Docker需要对其体系结构中的几个关键概念有所了解,主要包括image、container、service、swarm、stack等。

在介绍这几个概念时,会使用到一个测试环境,这个测试环境是一个由一台manager和一台worker构成的swarm,并且在两个node上都部署了weilu2/myrep:demo1这个镜像,只在manager这个node上部署了dockersamples/visualizer这个镜像。

Image
Image是一个轻量级的,独立的,可执行的包,其中包含了运行一个程序所必须的所有内容,包括代码,运行环境,类库,环境变量以及配置文件等。

使用命令可以查看所有的image:

docker images

结果:

REPOSITORY                 TAG                 IMAGE ID            CREATED             SIZE
friendlyhello latest a0a4a49f2713 hours ago 150MB
weilu2/myrep demo1 a0a4a49f2713 hours ago 150MB
python 2.7-slim a15e375b7949 hours ago 138MB
hello-world latest 05a3bd381fc2 weeks ago .84kB
dockersamples/visualizer <none> 8dbf7c60cf88 months ago 148MB

Container
一个container是image的一个运行时实例,当image在内存中执行时就被称为container。

使用命令可以查看所有的container:

docker container ls

结果:

CONTAINER ID        IMAGE                             COMMAND             CREATED             STATUS              PORTS               NAMES
739543688d4b dockersamples/visualizer:stable "npm start" hours ago Up hours /tcp stlab_visualizer..fg2b1hqvnj2mq3m9w45yuz6kn
bf9303546953 weilu2/myrep:demo1 "python app.py" hours ago Up hours /tcp stlab_web..0h9g8d449c63uz06gf3ugcy21
16fb0dea04cb weilu2/myrep:demo1 "python app.py" hours ago Up hours /tcp stlab_web..hkpsnerqii2kgp880ln5l1n8v

通过观察结果可以发现,image部署在每一个node上就会形成一个container,因此可以理解为container是只在单个node上运行的image。

Service
一个服务是指程序其中的一个部分,比如对于一个大型应用来说,文件存储作为一个单独的服务提供使用,一个服务可以包含若干个container,服务的规模是可以伸缩的。

可以使用命令查看Service:

docker service ls

结果:

ID                  NAME                MODE                REPLICAS            IMAGE                             PORTS
thz266xdqokf stlab_visualizer replicated / dockersamples/visualizer:stable *:->/tcp
agqm6iq2jtlu stlab_web replicated / weilu2/myrep:demo1 *:->/tcp

通过对比前面的image、container以及这个service的结果,可以发现其三者之间的关系,一个service实际上是指一个image运行的所有container的总称。不管这个image运行在多少个node上。

Swarm

Swarm是指一组运行着docker的机器构成的集群。在一个swarm中包含若干个Node(节点),其中有一个swarm manager节点,作为管理整个swarm的存在,其余还有若干个节点作为worker存在。

一台机器同一时间只能存在于一个swarm中。

Node

Swarm中的机器被称为节点,可以使用命令查看:

docker node ls

结果:

ID                            HOSTNAME            STATUS              AVAILABILITY        MANAGER STATUS
w0mk0httmn11nencbmw9yk0xp * centos7- Ready Active Leader
yn8btfa3qvcozwcneh15hh9ju centos7- Ready Active

其中centos7-1是manager,根据后面的标识可以看出来。管理swarm的所有命令必须在manager这个节点上执行才有效果,包括该条命令。

Stack

Stack是指一组共享依赖的相关的服务。

可以使用命令查看stack:

docker stack ls

结果:

NAME                SERVICES
stlab

根据这个结果可以看到这个stack中包含两个services,实际上就是上面使用service ls命令查看到的两个service。

使用命令可以查看某个stack下包含的service:

docker stack services stlab

最后一个参数是指stack的名字,结果如下:

ID                  NAME                MODE                REPLICAS            IMAGE                             PORTS
agqm6iq2jtlu stlab_web replicated / weilu2/myrep:demo1 *:->/tcp
thz266xdqokf stlab_visualizer replicated / dockersamples/visualizer:stable *:->/tcp

Task

Task是指在service中运行的一个container。可以使用命令查看某个stack下的task:

docker stack ps stlab

结果:

ID                  NAME                     IMAGE                             NODE                DESIRED STATE       CURRENT STATE          ERROR                              PORTS
moi9ubcbq6j9 stlab_web. weilu2/myrep:demo1 centos7- Running Running hours ago
fg2b1hqvnj2m stlab_visualizer. dockersamples/visualizer:stable centos7- Running Running hours ago
pu2ax0o6rq5f \_ stlab_visualizer. dockersamples/visualizer:stable centos7- Shutdown Rejected hours ago "No such image: dockersamples/…"
l6peeaqkufkm stlab_web. weilu2/myrep:demo1 centos7- Running Running hours ago
hkpsnerqii2k stlab_web. weilu2/myrep:demo1 centos7- Running Running hours ago
0h9g8d449c63 stlab_web. weilu2/myrep:demo1 centos7- Running Running hours ago
jo9c0fld9foq stlab_web. weilu2/myrep:demo1 centos7- Running Running hours ago

Docker关键概念阐述的更多相关文章

  1. Docker教程:docker的概念及安装

    http://blog.csdn.net/pipisorry/article/details/50754385 Why docker 对于运维来说,Docker提供了一种可移植的标准化部署过程,使得规 ...

  2. 后端技术杂谈9:先搞懂Docker核心概念吧

    本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...

  3. 菜鸟系列docker——docker基本概念(1)

    docker基本概念 1.准备 这里先介绍容器技术,后续再介绍docker.docker是容器的一种,除docker以外,还存在coreos.不过在当前趋势下容器和docker基本上可以划为等号了. ...

  4. docker核心概念(镜像、容器、仓库)及基本操作

    概要 docker是一种linux容器技术.容器有效的将由单个操作系统挂管理的资源划分到孤立的组中,以便更好的在组之间平衡有冲突的资源使用需求.可简单理解为一种沙盒 .每个容器内运行一个应用,不同的容 ...

  5. Docker 核心概念、安装、端口映射及常用操作命令,详细到令人发指。

    Docker简介 Docker是开源应用容器引擎,轻量级容器技术. 基于Go语言,并遵循Apache2.0协议开源 Docker可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...

  6. Kafka学习之(一)了解一下Kafka及关键概念和处理机制

    Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模小打的网站中所有动作流数据.优势 高吞吐量:非常普通的硬件Kafka也可以支持每秒100W的消息,即使在非常廉价的商用机器上也能做 ...

  7. Docker 基础概念科普 和 常用操作介绍

    Docker 基础概念 Docker是什么?         Docker的思想来自于集装箱,集装箱解决了:在一艘大船上,可以把货物规整的摆放起来.并且各种各样的货物被集装箱标准化了,集装箱和集装箱之 ...

  8. 【NS-3学习】ns3-模拟基础:关键概念,日志,命令行参数

    前言 本篇博客先介绍在仿真过程中会使用到的一些关键概念,然后介绍便于调试仿真脚本的常用技术:日志.命令行参数. 关键概念 节点 在因特网术语中,主机(终端)是指任何一台连接到网络的计算设备.ns-3并 ...

  9. Docker基本概念及架构

    一.Docker基本概念 Docker是一个开源的容器引擎,基于Go 语言并遵从 Apache2.0 协议开源.Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布 ...

随机推荐

  1. mac 下的操作

    nodejs在Mac下的卸载 在 node 官网上下载的安装包,用安装包安装的node.应该可以用一下命令行卸载: 在终端输入以下命令: sudo rm -rf /usr/local/{bin/{no ...

  2. Repeater循环页面上的控件

    List<string> list = new List<string>(); for (int k = 0; k < RepeaterList.Items.Count; ...

  3. mysql使用存储过程,批量生成测试数据

    1.存储过程代码 delimiter $$DROP PROCEDURE IF EXISTS create_service_data$$create procedure create_service_d ...

  4. deep_learning_Function_tensorboard的使用

    数据可视化(网页能打开,但是没有数据):https://jingyan.baidu.com/article/e9fb46e1c55ac93520f7666b.html

  5. three.js之正投影摄像机与透视投影摄像机的区别

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. Hadoop_11_HDFS的流式 API 操作

    对于MapReduce等框架来说,需要有一套更底层的API来获取某个指定文件中的一部分数据,而不是一整个文件 因此使用流的方式来操作 HDFS上的文件,可以实现读取指定偏移量范围的数据 1.客户端测试 ...

  7. BZOJ 1015 并查集&连通块

    很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这些星球通过特殊的以太隧道互相直接或 ...

  8. pycharm 快捷键及一些常用设置

    pycharm中的快捷键及一些常用设置 在PyCharm /opt/pycharm-3.4.1/help目录下可以找到ReferenceCard.pdf快捷键英文版说明 PyCharm Default ...

  9. .net core 读取appsettings 的配置

    { "Logging": { "IncludeScopes": false, "LogLevel": { "Default&quo ...

  10. 一键生成 dao service serverImpl controller 层

    package com.nf147.policy_publishing_platform.util.auto; import java.io.File; import java.io.FileWrit ...