之前一直用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
...下略
    deploy:
      mode: global
 

一 配置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 进行部署的更多相关文章

  1. docker kubernetes Swarm容器编排k8s CICD部署

    1docker版本 docker 17.09 https://docs.docker.com/ appledeAir:~ apple$ docker version Client: Docker En ...

  2. docker探索-swarm搭建docker集群(七)

    前言 Swarm 在 Docker 1.12 版本之前属于一个独立的项目,在 Docker 1.12 版本发布之后,该项目合并到了 Docker 中,成为 Docker 的一个子命令,docker s ...

  3. Docker - 通过swarm 管理 docker service

    创建一个 Docker service $ docker service create --replicas 1 --name myhelloworld alpine ping docker.com ...

  4. Dockerfile & Docker Swarm & Docker Stack & Docker Compose

    Dockerfile 通俗地讲,它是为了指导单个镜像从无到有的构建过程.如果你镜像是从Docker registry上面拉下来的,那就用不到这个文件:如果你是自己的应用,想打包成镜像,那就需要这个文件 ...

  5. 【翻译】Docker Compose 与Docker Stack的不同

    翻译原文 Docker引擎在1.12 版本集成了Docker Swarm,  带来了一些新工具. 现在可以无需安装 Docker Compose, 就可以利用docker-compose.yml 文件 ...

  6. 小白学Docker之Swarm

    承接上篇文章:小白学Docker之Compose,自学网站来源于https://docs.docker.com/get-started 系列文章: 小白学Docker之基础篇 小白学Docker之Co ...

  7. DOCKER 学习笔记8 Docker Swarm 集群搭建

    前言 在前面的文章中,已经介绍如何在本地通过Docker Machine 创建虚拟Docker 主机,以及也可以在本地Windows 创建虚拟主机,也是可以使用的.这一节,我们将继续学习 Docker ...

  8. Docker - 使用Swarm和compose部署服务(containers)

    前言 在之前使用Docker的过程中,一直是用 Docker run 命令单独启动container后再加入Overlay网络的方式实现部署工作的. 这种方式看似直接,但是随着服务所包含的contai ...

  9. Docker Swarm Mode 学习笔记 (部署服务)

    使用 docker service 命令来管理 Swarm 集群中的服务,该命令只能在管理节点上执行. 新建服务 docker service create --replicas 3 -p 80:80 ...

随机推荐

  1. Tesseract机器识别

    1.合并图片打开jtessboxeditor,点击Tools->Merge Tiff ,按住shift键选择前文提到的101个tif文件,并把生成的tif合并到新目录d:\python\lnyp ...

  2. Codeforces 1237B. Balanced Tunnel

    传送门 这一题有点意思 首先预处理出 $pos[x]$ 表示编号 $x$ 的车是第几个出隧道的 然后按进入隧道的顺序枚举每辆车 $x$ 考虑有哪些车比 $x$ 晚进入隧道却比 $x$ 早出隧道 显然是 ...

  3. 怎样禁止 html 中 <textarea> 标签可以拉伸改变大小 ?

    1. 一般来说, 使用 <textarea> 这个标签都会禁用掉它的这个默认属性, 不然可能会被用户玩儿坏, 而且也不利于其他元素的展示, 使用到的属性是 resize , 改为 none ...

  4. Js 更换html同一父元素下子元素的位置

    //更换两个元素的位置 var exchange=function (el1, el2) { var ep1 = el1[0].parentNode, ep2 = el2[0].parentNode, ...

  5. 详解CSS居中布局技巧

    本文转自:https://zhuanlan.zhihu.com/p/25068655#showWechatShareTip一.水平居中元素: 1.通用方法,元素的宽高未知方式一:CSS3 transf ...

  6. O057、Delete Volume 操作

    参考https://www.cnblogs.com/CloudMan6/p/5648665.html   状态为Available 的volume 才能够被delete,如果volume当前已经被at ...

  7. vccode配合svn

    先安装插件 要实现版本对比.需要先安装svn服务端 vue插件 微信小程序插件

  8. CSS基础:text-overflow:ellipsis溢出文本显示省略号的详细方法_CSS教程

    4要素: width: 125px;  //宽度必须 text-overflow: ellipsis/clip; //省略号或裁剪: white-space: nowrap;//强制内容在一行显示; ...

  9. js小功能2:切换

    HTML: <div id="tb"> <ul><li class="on">房产</li><li> ...

  10. vue +echarts树状图

    <template> <div :class="className" :id="id" :style="{height:height ...