docker stack /swarm 替代 docker-compose 进行部署
之前一直用docker-compose开发了几个单例的service, 今天开始压力测试, 结果发现postgres的CPU负载很重, 就想设置cpus 结果发现docker-compose V3之后 只能写在deploy字段里, 但是docker-compose up 却不支持 deploy
https://docs.docker.com/compose/compose-file/#deploy
说只能用swarm 模式. 这等于说V3的 docker compose 不能直接设定这个?
现在把swarm启动搞定了. 大概明白docker的意思了:
编辑同一份docker-compose.yml, 但是compose 和 swarm/stack的分工是这样的:
docker-compose 用于dev 支持build restart 但是不支持deploy,
swarm/stack 用于 prod 支持 deply的各种设置,包括分配cpu和内存, 但是创建容器只支持从image,不支持build.
假设已经用docker-compose基本开发完毕. 那么准备工作是这样:
一 docker-compose.yml
swarm模式, 每个serive都必须有image,不能只有build.
最简单的方法,就是先docker-compose up --build 启动运行无误
然后docker image ls 查看创建出的镜像名字
抄到每个Service下面,
然后,别忘了增加deploy字段, 尤其是mode, 对单例, 设置为global
yml形如:
version: '3.7 services: gateway: #nodejs + socket.io server
image: lh2-runtime_gateway
build: ./machines/lh2-gateway
...下略
一 配置swarm
在docker-compose.yml的路径下(就是原来运行docker-compose的路径)
docker swarm init

具体细节略过了, 简单说,我们的manager和worker都是这同一台机器的话, 这一句就够了, 不用join别的了
二. stack
docker stack deploy -c docker-compose.yml stack-demo
使用 docker-compose.yml 创建 stack (也就是一堆service),

这样服务其实已经创建好了.
但发现其实服务并没有在线. 检查一下

replicas 是服务copy的数量, 每个最大1一个,但是当前活动都是0, 全都没启动起来
继续查具体1个service, 用 id

发现不断报错, ."Pool overlaps with other one …"
这是和networks有关,根据
https://blog.csdn.net/u010483897/article/details/88017387
要删除 docker-compose.yml 创建的networks 否则一会服务因为端口相同都rejected
查看一下docker 的网络
docker network ls

最后一个的scope 是swarm , driver 时 overlay的 是刚刚创建的,需要保留的
那么前面 bridge local 那个,是需要删除的

删除之后,再查看刚才那个服务, 已经提示启动成功, 没有错误了

显示 数量都是 1/1 因为全是global
此时已经可以使用服务了.
docker stats 可以查看到服务全在运行,和用docker-compse up 时 一样

总结
基本无坑,比想象的容易. 吃完晚饭2个小时基本从完全不懂到部署成功了. 也不用太去管什么叫swarm ,什么 叫 stack ,先运行起来再说.
感觉还是部署和开发环境 完全分开在不同机器上比较好. 不然, 用 docker-compose build 的时候,还是要重新删除,创建一遍networks. 但是穷人没办法呀. 也将就了.
切换会docker-compose 的时候 找不到networks https://stackoverflow.com/questions/53347951/docker-network-not-found
docker-compose up --force-recreate
然而, 用swarm 部署后的效果,感觉和docker-comppse 并没有什么区别...
docker stack /swarm 替代 docker-compose 进行部署的更多相关文章
- docker kubernetes Swarm容器编排k8s CICD部署
1docker版本 docker 17.09 https://docs.docker.com/ appledeAir:~ apple$ docker version Client: Docker En ...
- docker探索-swarm搭建docker集群(七)
前言 Swarm 在 Docker 1.12 版本之前属于一个独立的项目,在 Docker 1.12 版本发布之后,该项目合并到了 Docker 中,成为 Docker 的一个子命令,docker s ...
- Docker - 通过swarm 管理 docker service
创建一个 Docker service $ docker service create --replicas 1 --name myhelloworld alpine ping docker.com ...
- Dockerfile & Docker Swarm & Docker Stack & Docker Compose
Dockerfile 通俗地讲,它是为了指导单个镜像从无到有的构建过程.如果你镜像是从Docker registry上面拉下来的,那就用不到这个文件:如果你是自己的应用,想打包成镜像,那就需要这个文件 ...
- 【翻译】Docker Compose 与Docker Stack的不同
翻译原文 Docker引擎在1.12 版本集成了Docker Swarm, 带来了一些新工具. 现在可以无需安装 Docker Compose, 就可以利用docker-compose.yml 文件 ...
- 小白学Docker之Swarm
承接上篇文章:小白学Docker之Compose,自学网站来源于https://docs.docker.com/get-started 系列文章: 小白学Docker之基础篇 小白学Docker之Co ...
- DOCKER 学习笔记8 Docker Swarm 集群搭建
前言 在前面的文章中,已经介绍如何在本地通过Docker Machine 创建虚拟Docker 主机,以及也可以在本地Windows 创建虚拟主机,也是可以使用的.这一节,我们将继续学习 Docker ...
- Docker - 使用Swarm和compose部署服务(containers)
前言 在之前使用Docker的过程中,一直是用 Docker run 命令单独启动container后再加入Overlay网络的方式实现部署工作的. 这种方式看似直接,但是随着服务所包含的contai ...
- Docker Swarm Mode 学习笔记 (部署服务)
使用 docker service 命令来管理 Swarm 集群中的服务,该命令只能在管理节点上执行. 新建服务 docker service create --replicas 3 -p 80:80 ...
随机推荐
- Java反射理解(四)-- 获取成员变量构造函数信息
Java反射理解(四)-- 获取成员变量构造函数信息 步骤 获取成员变量信息: obj.getClass() 获取类类型对象 成员变量也是对象,java.lang.reflect.Field 类中封装 ...
- lua的数据类型
Lua 是动态(弱)类型的语言,它有一下几种数据结构: nil(空) nil 类型表示一种没有任何有效值,它只有一个值 -- nil,例如打印一个没有赋值的变量,便会输出一个 nil 值: print ...
- Java函数式接口
函数式接口定义且只定义了一个抽象方法.函数式接口的抽象方法的签名称为函数描述符.Java 8的java.util.function包中引入了几个新的函数式接口. 1.Predicate java.ut ...
- Java基础第二天--多态、接口
多态 多态的概述 同一个对象,在不同时刻表现出来的不同形态 多态的前提和体现 有继承/实现关系 有方法重写关系 有父类引用指向子类对象 public class Animal { public voi ...
- linux系统编程相关
基本的概念:程序,进程,并发,单道程序设计,多道程序设计,时钟中断. 存储介质:寄存器(操作系统的位数是针对寄存器而言的,32位识字节,64位就是8字节).缓存cache.内存,硬盘,网络. cpu的 ...
- YII2中controller中的behaviors中的behavior内部是如何被使用的?
1. behaviors方法的调用: 在祖先对象components中有一个ensureBehaviors方法,代码如下: /** * Makes sure that the behaviors de ...
- vue 入门1 组件管理
全局 组件.局部组件 // Vue.component('todo-list',{ // template:'<li >item</li>' // }); //全局 // va ...
- U盘加载速度慢的解决方法
在日常的生活和工作中,我们经常用U盘存储一些文件和程序.然而,一些朋友发现U盘有时候在使用过程中的识别加载速度非常缓慢.是U盘出故障了吗?其实不尽然,下面就为大家分享一下如何快速解决U盘加载缓慢的方法 ...
- 第五章· MySQL数据类型
一.数据类型介绍 1.四种主要类别  1)数值类型 2)字符类型 3)时间类型 4)二进制类型 2.数据类型的 ABC 要素 1)Appropriate(适当) 2)Brief(简洁) 3)Comp ...
- 笔记 前端的$dom操作
jqueryDOM操作 1. 页面加载 函数 $( function(){ 具体内容 } ); 表示页面加载函数 2 dom 类操作 text() - 设置或返回所选元素的文 ...