美文网首页Docker容器Awesome Docker
6.Docker入门(五)多服务组成Stack

6.Docker入门(五)多服务组成Stack

作者: 爱迪生玛玛 | 来源:发表于2017-05-26 21:42 被阅读742次

注意

以下内容完全摘自Docker官方文档,仅为学习及技术分享所用,切勿用于商业用途,转载请注明出处。

以下为正文


了解Stack

在Docker中,我们把一组相互关联、相互依赖、共同协作完成某些业务功能的服务称为一个Stack(服务栈)。一个Stack应该可以定义和完成整个应用程序的功能,当然一些较复杂的应用程序可以由多个Stack构成。简而言之:Stack就是一组服务的集合。
接下来,我们在学完 ServiceSwarm 的基础上,利用之前编写的docker-compose.yml和swarm集群,添加另外两个服务:visualizer和redis,实现可视化显示集群中container的状态和存储集群访问次数的功能,组成我们的第一个Stack。

添加visualizer服务

visualizer是Docker官方开发的一个服务,利用它可以可视化显示集群中container的调度情况。如果想了解更多,可以到visualizer的github
打开docker-compose.yml,将内容替换成以下代码:

version: "3"
services:
  web:
    image: username/repo:tag
    deploy:
      replicas: 5
      restart_policy:
        condition: on-failure
      resources:
        limits:
          cpus: "0.1"
          memory: 50M
    ports:
      - "80:80"
    networks:
      - webnet
  visualizer:
    image: dockersamples/visualizer:stable
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
    networks:
      - webnet
networks:
  webnet:

这里,我们为web服务添加了一个监听服务: visualizer。我们为visualizer服务指定了两个键值,volumes和deploy。volumes映射容器中/var/run/docker.sock到宿主机的/var/run/docker.sock文件中,deploy键通过添加contraints:[node.role==manager]指定visualizer只会部署在swarm manager节点上,而不会部署在worker节点上。因为只有在swarm manager上,才可以对整个集群进行管理,才能监听到整个集群的状态。

接下来,我们把这个新的docker-compose.yml发送到myvm1这台虚机上。

docker-machine scp docker-compose.yml myvm1:~

然后重新部署应用

$ docker-machine ssh myvm1 "docker stack deploy -c docker-compose.yml getstartedlab"
Updating service getstartedlab_web (id: angi1bf5e4to03qu9f93trnxm)
Updating service getstartedlab_visualizer (id: l9mnwkeq2jiononb5ihz9u7a4)

可以看到,两个服务组件都得到了更新,通过访问myvm1或者myvm2中任一台实例的8080端口,可以看到visualizer显示的效果如下图:

get-started-visualizer1.png

添加redis服务显示访问次数

将docker-compse.yml内容替换如下:

version: "3"
services:
  web:
    image: username/repo:tag
    deploy:
      replicas: 5
      restart_policy:
        condition: on-failure
      resources:
        limits:
          cpus: "0.1"
          memory: 50M
    ports:
      - "80:80"
    networks:
      - webnet
  visualizer:
    image: dockersamples/visualizer:stable
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
    networks:
      - webnet
  redis:
    image: redis
    ports:
      - "6379:6379"
    volumes:
      - ./data:/data
    deploy:
      placement:
        constraints: [node.role == manager]
    networks:
      - webnet
networks:
  webnet:

这里我们做了以下几件事:

  • 添加了redis服务,由于它是Docker官方正式提供的镜像文件,所以无需指定username和tag,直接用小写的redis就可以定位到镜像。
  • 将6379端口公开并映射到宿主机的6379端口,6379是Redis默认配置的对外端口,您可以通过集群中任一主机IP地址加上6379端口访问Redis Desktop Manager(Redis自带管理界面)。
  • volumes将/data目录映射到宿主机./data目录,/data是redis默认存储数据的目录,通过这样的映射,即使容器挂了或者重新部署,数据都已经保留到了宿主机上,不会丢失。
  • deploy通过constraints将redis部署到swarm manager节点上。

接下来,我们需要在myvm1实例(即redis服务容器所在宿主机)上创建./data目录,然后重新部署我们的应用,依次执行以下命令:

$ docker-machine ssh myvm1 "mkdir ./data"
$ docker-machine scp docker-compose.yml myvm1:~
$ docker-machine ssh myvm1 "docker stack deploy -c docker-compose.yml getstartedlab"

部署完后,再次访问集群中任一个实例的IP地址(端口为80),即访问我们部署的web服务,就可以看到一个显示访问次数的界面了(我们的web服务组件其实已经包含了我们在创建Docker镜像章节中用python写的使用redis存储访问次数的程序app.py)。

至此,您就构建了一个集web负载均衡、visualizer图形界面、redis存储的Stack。

相关文章

  • 6.Docker入门(五)多服务组成Stack

    注意 以下内容完全摘自Docker官方文档,仅为学习及技术分享所用,切勿用于商业用途,转载请注明出处。 以下为正文...

  • Docker

    Docker入门教程 Docker组成 1.docker服务端,docker服务端是一个服务进程,管理着所有的容器...

  • 使用 Docker Stack 部署多服务集群

    前言 单机模式下,我们可以使用 Docker Compose 来编排多个服务,而在上一篇文章中介绍的 Docker...

  • ELK Stack入门

    Elasticsearch简介 一个采用RestFulAPI标准的高扩展性和高可用性的实时数据分析的全文搜索工具 ...

  • 入门Elastic Stack

    正在找Elastic Stack(ELK)指南,那本介绍如何搭建Elastic Stack和快速启动运行的宝典?那...

  • Elastic stack入门

    1.Elasticsearcch 安装与运行 1.1安装JDk1.8 1.2去elasticsearch官网下载 ...

  • SKIL中文文档V1.2

    开始  快速入门  系统概述  下载  安装    Docker镜像    单服务器    多服务器    ...

  • 转:服务端工程师入门与进阶 Java 版

    这是一份针对实习生/毕业生的服务端开发入门与进阶指南。 建议: 尽量用google查找技术资料。有问题在stack...

  • 带你认识物理机服务器(非原创)

    文章大纲 一、物理服务器常见知识二、物理服务器具体组成三、物理服务器类型四、物理服务器内部组成五、参考文章 一、物...

  • 微服务架构入门

    微服务架构入门 1. 微服务简介 微服务是一种架构风格,一个大型的复杂软件由一个或多个微服务组成。系统中每个微服务...

网友评论

    本文标题:6.Docker入门(五)多服务组成Stack

    本文链接:https://www.haomeiwen.com/subject/mhnxfxtx.html