===============================================

2019/4/9_第3次修改                       ccb_warlock

更新说明:

2019/4/9:重新整理了docker swarm的部署步骤

2018/12/14:精简docker-compose部署的命令;

增加18.09.0-ce以后的hosts(2.3 配置hosts信息)配置方法;

===============================================

由于k8s的方案被搁置了,目前只能先考虑使用swarm搭建小规模的集群。经过几天对swarm的使用,对于与docker相关的docker-compose、service、stack相关内容有了更明确的理解。对比swarm与k8s也是各有千秋。

2019/4/9,重新整理了swarm的部署顺序,将docker的安装部分拆分到centos7 部署 docker ce,根据节点类型分别整理了部署步骤。


一、准备工作

1.1 修改主机名(可以不修改)

为了便于区分节点,用主机名来标记节点
manager节点执行:

hostnamectl --static set-hostname manager01

worker节点执行:

hostnamectl --static set-hostname worker01

修改完后,重新开shell控制台。


二、管理节点(Manager)

2.1 安装docker ce

可以参考下面的文章安装docker ce

centos7 部署 docker ce:https://www.cnblogs.com/straycats/p/10680502.html

2.2 配置hosts信息

2.2.1 18.06.1-ce及以前版本

# 修改docker daemon配置

mkdir -p /etc/docker
vim /etc/docker/daemon.json

增加hosts的内容,wq保存。

{
"hosts": ["tcp://0.0.0.0:2375","unix:///var/run/docker.sock"]
}

2.2.2 18.09.0-ce及以后版本

systemctl edit docker

将下面的内容添加到文件(/etc/systemd/system/docker.service.d/override.conf)中,wq保存。

[Service]
ExecStart=
ExecStart=/usr/bin/dockerd -H unix:///var/run/docker.sock -H tcp://0.0.0.0:2375

# 重新加载systemctl的配置

systemctl daemon-reload

2.3 重启docker

systemctl restart docker

2.4 创建swarm集群

# 初始化swarm集群(我使用的虚拟机IP为192.168.12.11)

docker swarm init

# 创建集群(当宿主机有多个IP时,需要指定IP)

docker swarm init --advertise-addr 192.168.12.11

创建后,该节点为manager节点(leader)。

如果需要添加其他管理节点,可以使用下面的命令查看作为管理节点加入集群的命令。

docker swarm join-token manager 

三、工作节点(Worker)

3.1 安装docker ce

可以参考下面的文章安装docker ce

centos7 部署 docker ce:https://www.cnblogs.com/straycats/p/10680502.html

3.2 配置hosts信息

3.2.1 18.06.1-ce及以前版本

# 修改docker daemon配置

mkdir -p /etc/docker
vim /etc/docker/daemon.json

增加hosts的内容,wq保存。

{
"hosts": ["tcp://0.0.0.0:2375","unix:///var/run/docker.sock"]
}

3.2.2 18.09.0-ce及以后版本

systemctl edit docker

将下面的内容添加到文件(/etc/systemd/system/docker.service.d/override.conf)中,wq保存。

[Service]
ExecStart=
ExecStart=/usr/bin/dockerd -H unix:///var/run/docker.sock -H tcp://0.0.0.0:2375

# 重新加载systemctl的配置

systemctl daemon-reload

3.3 重启docker

systemctl restart docker 

3.4 将该工作节点添加到swarm集群中

# 查看作为工作节点接入集群的命令

docker swarm join-token worker

# 将自己注册到该集群(192.168.12.11)

docker swarm join --token SWMTKN-1-1w1q09p1z37n4j24usz9lwb0i01t2ecuxn4ad5ctfdpks4270r-5p5mmiw6u77skwd49sxovztxc 192.168.12.11:2377

PS.命令中的token信息根据实际情况更换。


参考资料:

1.https://stackoverflow.com/questions/51923078/unable-to-start-the-docker-daemon-if-file-etc-docker-daemon-json-exist

2.https://docs.docker.com/engine/reference/commandline/dockerd/

centos7 部署 docker swarm的更多相关文章

  1. centos7 部署 docker compose

    =============================================== 2019/4/10_第1次修改                       ccb_warlock == ...

  2. centos7 部署 docker ce

    =============================================== 2019/4/9_第1次修改                       ccb_warlock === ...

  3. centos7 部署 docker、shipyard

    =============================================== 2019/4/9_第3次修改                       ccb_warlock 更新说 ...

  4. 部署docker swarm集群

    基础环境 机器名称 IP地址 安装的软件 node-1 192.168.10.190 docker-ce node-2 192.168.10.191 docker-ce node-3 192.168. ...

  5. CentOS-7部署Docker容器

    为了适应当前容器化的部署方式,故最近也在对docker进行学习.目前的理解是docker服务就像一艘货船,而你的各项服务可以封装在一个个集装箱里,而且在docker里服务的启动非常快,故有必要从基础的 ...

  6. 通过docker-machine和etcd部署docker swarm集群

    本片文章介绍一下 使用docker-machine 搭建docker swarm 集群:docker swarm是docker 官方搭建的容器集群编排工具:容器编排,就是可以使你像使用一太机器一样来使 ...

  7. centos7 在docker swarm中运行Jenkins,利用gitlab的webhook触发自动部署脚本

    1.宿主机中创建目录 mkdir -p /jenkins_home 2.编辑compose文件,文件名jenkins.yml version: '3.4' services: jenkins-upgr ...

  8. 容器基础(八): 使用docker swarm部署程序

    环境 基于上一节的env/server:v0.1, env/worker:v0.1镜像, 在基于debian8.2的两台机器上测试部署docker swarm. docker service部署 ➜ ...

  9. 故障公告:docker swarm集群“群龙无首”引发部分站点无法访问

    今天傍晚 17:38-18:18 左右,由于 docker swarm 集群出现 "The swarm does not have a leader" 问题,造成博问.闪存.园子. ...

随机推荐

  1. ELK之消息队列选择redis_kafka_rabbitmq

    前言描述 生产初级,Service服务较少,访问量较少,随着业务量的不断增加,日志量成倍增长,然后就遇到了消息队列redis被充爆,不能满足应用的情况.针对此情况,我们来分析下可用的消息多列. 官方推 ...

  2. javascript面向对象系列第五篇——拖拽的实现

    前面的话 在之前的博客中,拖拽的实现使用了面向过程的写法.本文将以面向对象的写法来实现拖拽 写法 <style> .test{height: 50px;width: 50px;backgr ...

  3. [代码]--其他信息: ORA-01400: 无法将 NULL 插入

    这个错误其实就是oracle数据库的某列约束为 not null,但在插入值的时候插入了控制,无论是null和"",它都识别为空 有两种方法: 1.修改数据库字段约束为允许为空 2 ...

  4. 如何整合Office Web Apps至自己开发的系统(一)

    在前面我的一篇博客中 Office Web Apps安装部署(一),有一张介绍Office Web Apps与其他系统的关系图,   从上述图中,可知实际上Office Web Apps也是可以接入自 ...

  5. Debian8 系统修改语言设置成英文

    本文摘自 https://wiki.debian.org/ChangeLanguage ,感谢作者 * First, you have to set environment variables suc ...

  6. Qt ------ 自定义QVector<T>中的T

    #ifndef FREQUENCYSPECTRUM_H #define FREQUENCYSPECTRUM_H #include <QtCore/QVector> /** * Repres ...

  7. java回顾(项目前期的基本准备)

    一.     基础回顾 1   集合 1.1 集合的类型与各自的特性 ---|Collection: 单列集合 ---|List: 有存储顺序, 可重复 ---|ArrayList:  数组实现, 查 ...

  8. 浮动和margin-left负值的有趣现象

    我将第二个浮动的元素的margin-left的值不断减小: 被设置元素左移,后面的元素跟着动 当被设置元素的右边界超过了前面元素的左边界,后面边的元素被前面的元素挡在外面了

  9. faster rcnn 详解

    转自:https://zhuanlan.zhihu.com/p/31426458 经过R-CNN和Fast RCNN的积淀,Ross B. Girshick在2016年提出了新的Faster RCNN ...

  10. Spark记录-Scala函数

    Scala函数 Scala有函数和方法. Scala方法是一个具有名称和签名的类的一部分. Scala中的函数是一个可以分配给变量的完整对象. 函数定义可以出现在源文件中的任何位置. 不带参数的函数 ...