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 ...
随机推荐
- django时区与时间差的问题
时区的正确配置方式: # 这里还可以配置成中文 一般用不到 LANGUAGE_CODE = 'en-us' # TIME_ZONE = 'UTC' TIME_ZONE = 'Asia/Shanghai ...
- 使用python连接mysql数据库——pymysql模块的使用
安装pymysql pip install pymysql 使用pymysql 使用数据查询语句 查询一条数据fetchone() from pymysql import * conn = conne ...
- MySql 枚举和集合 详解
枚举与集合 枚举类型,enum 每个枚举值均有一个索引值: 在列说明中列表值所允许的成员值被从 1 开始编号. 一般来说就是单选,在定义枚举的时候列出所有的可能性: 代码如下 1. create ta ...
- L1-064 估值一亿的AI核心代码 (20 分)
L1-064 估值一亿的AI核心代码 (20 分) 以上图片来自新浪微博. 本题要求你实现一个稍微更值钱一点的 AI 英文问答程序,规则是: 无论用户说什么,首先把对方说的话在一行中原样打印出来: ...
- React高阶组件学习笔记
高阶函数的基本概念: 函数可以作为参数被传递,函数可以作为函数值输出. 高阶组件基本概念: 高阶组件就说接受一个组件作为参数,并返回一个新组件的函数. 为什么需要高阶组件 多个组件都需要某个相同的功能 ...
- Entity Framework:三种开发模式实现数据访问
原文地址 http://blog.csdn.net/syaguang2006/article/details/19606715 前言 Entity Framework支持Database First. ...
- plist文件的归档,解档
plist文件 plist的根Type只能是字典(NSDictionary)或者是数组(NSArray)所以归档时我们只能将数组或字典保存到plist文件中,但是NSString也能通过归档保存到pl ...
- 面向对象相关概念与在python中的面向对象知识(魔法方法+反射+元类+鸭子类型)
面向对象知识 封装 封装的原理是,其成员变量代表对象的属性,方法代表这个对象的动作真正的封装是,经过深入的思考,做出良好的抽象(设计属性时用到),给出“完整且最小”的接口,并使得内部细节可以对外透明( ...
- Java学习笔记【一、环境搭建】
今天把java的学习重新拾起来,一方面是因为公司的项目需要用到大数据方面的东西,需要用java做语言 另一方面是原先使用的C#公司也在慢慢替换为java,为了以后路宽一些吧,技多不压身 此次的学习目标 ...
- nohup命令(Linux终端启动后台运行程序)
1. nohup指令基本概念: nohup: 不挂断的运行,并没有后台运行功能,用nohup运行命令可以使命令永久执行下去,和用户终端没有关系,断开SSH不影响运行,&是后台运行. nohup ...