Docker Stack简介及使用

Docker Stack简介及使用

1.简介

Docker Compose的缺点是不能在分布式多服务器上使用,Docker swarm的缺点是不能同时编排多个服务,所以才有了Docker Stack,可以在分布式多服务器上同时编排多个服务。

2.使用实例

1.准备docker-compose文件

本地准备两个镜像后,编写compose文件/root/docker-compose.yml:

python 复制代码
version: "3.9"
services:
  service1:
    image: "masonzhang/service1:V1"
    deploy:
        replicas: 2
    ports:
      - "8080:8080"

  service2:
    image: "masonzhang/service2:V1"
    deploy:
        replicas: 3
    ports:
      - "8081:8081"

2.swarm集群搭建

可参考:docker swarm安装使用

3.stack部署

python 复制代码
$ docker stack deploy myapps --compose-file=/root/docker-compose.yml

4.stack其他操作

查看所有stack的信息

python 复制代码
$ docker stack ls

NAME      SERVICES   ORCHESTRATOR
myapps    2          Swarm

查看某个stack中的所有任务信息

python 复制代码
$ docker stack ps myapps

ID             NAME                IMAGE                    NODE      DESIRED STATE   CURRENT STATE
tvvujrf3qcr1   myapps_service1.1   masonzhang/service1:V1   node1     Running         Running 46 seconds ago       
igjeydmmvzzm   myapps_service1.2   masonzhang/service1:V1   manager   Running         Running 46 seconds ago       
7p5c96eplwl3   myapps_service2.1   masonzhang/service2:V1   node1     Running         Running 34 seconds ago       
7shglsajip5d   myapps_service2.2   masonzhang/service2:V1   manager   Running         Running 39 seconds ago       
upo0mr7j9tn1   myapps_service2.3   masonzhang/service2:V1   node2     Running         Preparing 41 seconds ago  

查看某个stack中的所有服务信息

python 复制代码
$ docker stack services myapps

ID             NAME              MODE         REPLICAS   IMAGE                    PORTS
icz3kjn0skb3   myapps_service1   replicated   2/2        masonzhang/service1:V1   *:8080->8080/tcp
myuzlwnrxag4   myapps_service2   replicated   3/3        masonzhang/service2:V1   *:8081->8081/tcp

移除stack

python 复制代码
docker stack rm myapps
相关推荐
峰顶听歌的鲸鱼9 小时前
Kubernetes介绍和部署
运维·笔记·云原生·容器·kubernetes·学习方法
信创天地10 小时前
自动化运维利器赋能信创:Ansible与SaltStack在国产系统的部署与批量管理实战
运维·自动化·ansible
东城绝神10 小时前
《Linux运维总结:基于ARM64+X86_64架构使用docker-compose一键离线部署MySQL8.0.43 NDB Cluster容器版集群》
linux·运维·mysql·架构·高可用·ndb cluster
creator_Li11 小时前
即时通讯项目--(1)环境搭建
linux·运维·ubuntu
Ka1Yan11 小时前
Docker:基本概念与快速入门
运维·docker·容器
文静小土豆12 小时前
Rocky Linux 二进制 安装K8S-1.35.0高可用集群
linux·运维·kubernetes
小技工丨12 小时前
华为TaiShan 200 2280 ARM服务器虚拟化部署完整指南
运维·服务器·arm开发
糠帅傅蓝烧牛肉面14 小时前
单实例多MCP聚合服务:两种实现方案深度对比
前端·docker·ai
4032407314 小时前
[Jetson/Ubuntu 22.04] 解决挂载 exFAT 硬盘报错 “unknown filesystem type“ 及只读权限问题的终极指南
linux·运维·ubuntu
零意@14 小时前
debian如何把新编译的内核镜像替换原来的内核
运维·debian·更新内核版本·linux内核版本更新·debian更新内核