Docker 自修笔记(四)

本文是作者JDGan关于Docker学习的笔记,主要讲解如何在已有Docker栈中添加新服务并重新部署,以及如何添加Redis数据库服务,包括指定服务部署节点和设置访问路径。
摘要由CSDN通过智能技术生成

本博客为JDGan自修Docker的笔记,如有粗鄙之处,还请见谅~

阅读本博客前,请确定掌握了前一篇blog:Docker 集群

Docker 栈

前面在上一章里,已经通过docker stack deploy部署了一个栈,但是实际应用当中,我们不可能只有一个栈,所以本章就多个栈的情况,进行介绍。

添加新服务并重新部署

打开前一章的docker-compose.yml,并新增一个服务visualizer

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:

按照上一章的流程,拷贝到集群控制器 Home 下,执行

$ docker stack deploy -c docker-compose.yml getstartedlab

直接通过浏览器访问<ip>:<port>,可以看到如下图所示的 Docker node图。

也可通过docker stack ps getstartedlab查看。

添加 redis 数据库服务

通过上面的方法,再添加redis服务到docker-compose.yml

  redis:
    image: redis
    ports:
      - "6379:6379"
    volumes:
      - ./data:/data
    deploy:
      placement:
        constraints: [node.role == manager]
    networks:
      - webnet

placement指定了该服务部署的节点角色位置
volumes指定redis可以通过/data访问./data,注意需要保证该目录的存在mkdir ./data
再次直接部署服务

$ docker stack deploy -c docker-compose.yml getstartedlab

这样就可以直接使用redis数据库服务了。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值