为了让学习的知识融汇贯通,目前是把所有的集群都放在了一个虚拟机上,如果这个虚拟机宕机了怎么办?俗话说鸡蛋不要都放在一个篮子里面,把各种集群的节点拆分部署,应该把各种节点分机器部署,多个宿主机,这样部署随便挂哪个主机我们都不担心。

源码:https://github.com/limingios/netFuture/blob/master/docker-swarm/

一起在说说docker swarm

swarm 是docker的三剑客一员,之前都说过了,可以看中级和高级啊 。

docker machine 容器服务

docker compose 脚本服务

docker swarm 容器集群技术

去中心化的设计

Swarm Manager 也承担worker节点的作用。

Swarm Worker 运行容器部署项目

Swarm是没有中心节点的,挂到其中一个其他是不会挂掉的。Swarm Manager 如果master挂了,立马选举一个新的master。

创建集群环境

首先机器已经安装了docker环境。

docker swarm init

加入swarm集群

#加入到manager中

docker swarm join-token manager

#加入到worker中

docker swarm join-token worker

环境搭建

应用

IP地址

服务

配置

安装应用

安装方式

docker-swarm-manager1

192.168.66.100

docker-swarm-manager1

单核 2g内存

docker-swarm-manager1

docker

docker-swarm-manager2

192.168.66.101

docker-swarm-manager2

单核 2g内存

docker-swarm-manager2

docker

docker-swarm-node1

192.168.66.102

docker-swarm-node1

单核 2g内存

docker-swarm-node1

docker

docker-swarm-node2

192.168.66.103

docker-swarm-node2

单核 2g内存

docker-swarm-node2

docker

docker swarm环境

一共4个节点,2个manager节点,2个work节点,manager不光是管理,而且也干活,说白了一共4个干活的节点。

创建docker swarm集群

su -

#密码vagrant

docker swarm init

报错注意:如果你在新建集群时遇到双网卡情况,可以指定使用哪个 IP,例如上面的例子会有可能遇到下面的错误。

Error response from daemon: could not choose an IP address to

advertise since this system has multiple addresses on different

interfaces (10.0.2.15 on enp0s3 and 192.168.66.100 on enp0s8)

- specify one with --advertise-addr

再次创建docker swarm集群192.168.66.100

docker swarm init --advertise-addr 192.168.66.100 --listen-addr 192.168.66.100:2377

docker swarm join-token manager

再次创建docker swarm集群192.168.66.101

当前节点以manager的身份加入swarm集群

docker swarm join --token SWMTKN-1-4itumtscktomolcau8a8cte98erjn2420fy2oyj18ujuvxkkzx-9qutkvpzk87chtr4pv8770mcb 192.168.66.100:2377

再次创建docker swarm集群192.168.66.102

当前节点以worker的身份加入swarm集群

docker swarm join --token SWMTKN-1-4itumtscktomolcau8a8cte98erjn2420fy2oyj18ujuvxkkzx-f2dlt8g3hg86gyc9x6esewtwl 192.168.66.100:2377

再次创建docker swarm集群192.168.66.103

当前节点以worker的身份加入swarm集群

docker swarm join --token SWMTKN-1-4itumtscktomolcau8a8cte98erjn2420fy2oyj18ujuvxkkzx-f2dlt8g3hg86gyc9x6esewtwl 192.168.66.100:2377

查看swarm集群

只能在manager节点内执行

leader挂掉后,reachable就可以管理集群了。

docker node ls

查看swarm集群的网络

只能在manager节点内执行

docker network ls

创建容器间的共享网络

只能在manager节点内执行

docker network create -d overlay --attachable swarm_test

docker network ls

目前是4台机器,如果想让4台机器内的容器可以进行共享,overlay的网络就可以了,只需要在创建容器的时候--net=swarm_test

创建5个pxc容器

192.168.66.100

创建2个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。

docker volume create v1

docker volume create backup1

#增加域名解析

echo "nameserver 8.8.8.8" | tee /etc/resolv.conf > /dev/null

sudo curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://b81aace9.m.daocloud.io

sudo systemctl restart docker

docker run -d -p 3306:3306 --net=swarm_test \

--name=node1 \

-e CLUSTER_NAME=PXC \

-e MYSQL_ROOT_PASSWORD=a123456 \

-e XTRABACKUP_PASSWORD=a123456 \

-v v1:/var/lib/mysql \

--privileged \

-v backup1:/data \

percona/percona-xtradb-cluster

docker ps

docker volume create v2

docker run -d -p 3307:3306 --net=swarm_test \

--name=node2 \

-e CLUSTER_NAME=PXC \

-e MYSQL_ROOT_PASSWORD=a123456 \

-e XTRABACKUP_PASSWORD=a123456 \

-v v2:/var/lib/mysql \

--privileged \

-v backup1:/data \

-e CLUSTER_JOIN=node1 \

percona/percona-xtradb-cluster

docker ps

192.168.66.101

创建1个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。

docker volume create v3

docker volume create backup3

docker run -d -p 3307:3306 --net=swarm_test \

--name=node3 \

-e CLUSTER_NAME=PXC \

-e MYSQL_ROOT_PASSWORD=a123456 \

-e XTRABACKUP_PASSWORD=a123456 \

-v v3:/var/lib/mysql \

--privileged \

-v backup3:/data \

-e CLUSTER_JOIN=node1 \

percona/percona-xtradb-cluster

docker ps

192.168.66.102

创建1个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。

docker volume create v4

docker volume create backup4

docker run -d -p 3307:3306 --net=swarm_test \

--name=node4 \

-e CLUSTER_NAME=PXC \

-e MYSQL_ROOT_PASSWORD=a123456 \

-e XTRABACKUP_PASSWORD=a123456 \

-v v4:/var/lib/mysql \

--privileged \

-v backup4:/data \

-e CLUSTER_JOIN=node1 \

percona/percona-xtradb-cluster

docker ps

192.168.66.103

创建1个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。

docker volume create v4

docker volume create backup4

docker run -d -p 3307:3306 --net=swarm_test \

--name=node4 \

-e CLUSTER_NAME=PXC \

-e MYSQL_ROOT_PASSWORD=a123456 \

-e XTRABACKUP_PASSWORD=a123456 \

-v v4:/var/lib/mysql \

--privileged \

-v backup4:/data \

-e CLUSTER_JOIN=node1 \

percona/percona-xtradb-cluster

docker ps

容器集群

在这个示意图里面,画了4个linux的主机,都安装了docker虚拟机,假如我现在想安装A程序,直接选择Docker-1这个主机里面的容器安装A程序,这样没有问题。但是单节点单容器来部署,一旦这个节点挂掉的话,A程序就没有,为了防止这样我们有冗余设计,直接在Docker-2这个主机里面的容器也安装A程序,这样的话,Docker-1里面的A程序挂了,Docker-2里面的A程序也可以运行。这个功能有点像负载均衡,其实真的很像。docker swarm提供的东西跟负载均衡还是有区别的。swarm 只是提供了容器状态的管理,如果Docker-1里面的A程序挂了,发现本来二个,现在变成1个了危险,立马在起一个吧。实时保证docker容器内的数量。

容器集群适合的场景

容器集群不适合有状态程序,例如数据库,缓存等等

退出Swarm集群

#Manager退出必须加--force

docker swarm leave --force

删除节点

service docker stop

#Manager节点需要先降级

docker node demoted

docker node rm

docker network

PS:这次主要说了3点比较重要的:通过docker-swarm的网络搭建容器化通信网络,创建集群的时候--net 加入docker-swarm创建的网络,方便通信。不哪些适合做容器化集群,数据库和缓存。如何操作docker-swarm中的节点。

swarm部署mysql_「实战篇」开源项目docker化运维部署-借助dockerSwarm搭建集群部署(九)...相关推荐

  1. 「实战篇」开源项目docker化运维部署-后端java部署(七)

    原创文章,欢迎转载.转载请注明:转载自IT人故事会,谢谢! 原文链接地址:「实战篇」开源项目docker化运维部署-后端java部署(七) 本节主要说说后端的部署需要注意的点,本身renren-fas ...

  2. mac远程redis_「实战篇」开源项目docker化运维部署-redis高速缓存(六)

    现在一般的项目都会用到redis做缓存,也不免有老铁没用过,我就一起说下吧.源码:https://github.com/limingios/netFuture/tree/master/redis-cl ...

  3. docker portainer_「实战篇」开源项目docker化运维部署-Portainer管理集群部署(十)...

    之前都是通过命令的方式,管理docker的,其实docker还是有图形界面的.使用图形界面如何管理docker,其实业界很多公司都对docker进行了图形化的封装.之前在初级和中级的时候也有界面mar ...

  4. 「实战篇」开源项目docker化运维部署-前端java部署(八)

    本节主要说说前端的部署需要注意的点,本身renren-fast这个项目就是通过nodejs来进行开发的,nodejs编译后生成html,css,img所以,咱们不用在容器直接用nginx就可以访问静态 ...

  5. python docker自动化_「docker实战篇」python的docker爬虫技术-移动自动化控制工具appium工具(17)...

    原创文章,欢迎转载.转载请注明:转载自 IT人故事会,谢谢! 原文链接地址: 「docker实战篇」python的docker爬虫技术-移动自动化控制工具appium工具(17) Appium是一个开 ...

  6. python docker自动化_「docker实战篇」python的docker爬虫技术-移动自动化控制工具安卓ADB的使用(15)...

    原创文章,欢迎转载.转载请注明:转载自 IT人故事会,谢谢! 原文链接地址: 「docker实战篇」python的docker爬虫技术-移动自动化控制工具安卓ADB的使用(15) adb(Androi ...

  7. 「docker实战篇」python的docker爬虫技术-在linux下mitmproxy介绍和安装(四)

    原创文章,欢迎转载.转载请注明:转载自IT人故事会,谢谢! 原文链接地址:「docker实战篇」python的docker爬虫技术-在linux下mitmproxy介绍和安装(四) 上次说了fiddl ...

  8. 「docker实战篇」python的docker爬虫技术-安卓模拟器(二)

    原创文章,欢迎转载.转载请注明:转载自IT人故事会,谢谢! 原文链接地址:「docker实战篇」python的docker爬虫技术-安卓模拟器(二) 为什么要手机模拟器,如果有条件正好有不使用的安卓手 ...

  9. fir.im Weekly - 如何打造 Github 「爆款」开源项目

    最近 Android 转用 Swift 的传闻甚嚣尘上,Swift 的 Github 主页上已经有了一次 merge>>「Port to Android」,让我们对 Swift 的想象又多 ...

最新文章

  1. 多视角图像生成--Multi-View Image Generation from a Single-View
  2. 生态篇-HBase 生态介绍
  3. MATLAB实战系列(三十三)-技术和医疗的完美结合(续),基于最小二乘法的椭圆拟合
  4. mysql中as用法
  5. Visual Studio 2013运行的结果一闪而过
  6. 闭门宅家后,才知道这15个“真相”
  7. centos uninstall teamviewer11
  8. 【CSS3】CSS3支持的颜色表示方法大全
  9. 寒假集训日志(二)——最小生成树,拓扑排序,欧拉回路,连通路
  10. 阿里云专有网络环境下不同账号之间内网互通(内网高速通道)
  11. Java的String/byte[]/16进制相互转换
  12. 入侵本地Mac OS X方针与技巧
  13. Linux下comm命令比较两个文件的异同
  14. 计算机数字模拟仿真软件,实时数字仿真系统
  15. 利用tensorflow加载VGG19
  16. 常见的数据结构与算法
  17. 计算机专业理学硕士,加州大学戴维斯分校
  18. 搭建一个简单的SDN网络环境
  19. 基于 Springboot 和 Mybatis 的后台管理系统 BootDo | 软件推介
  20. 聪明的大脑 少碰以下的食物!!

热门文章

  1. Linux 命令(126)—— ssh 命令
  2. Linux 命令(3)—— sed 命令
  3. C++ 数组与指针详解之终极无惑
  4. C#正则表达式判断字符串中是否有数…
  5. 微信机器人开发SDK使用教程--删除朋友圈
  6. phpstorm 的下载、安装与激活
  7. navicat如何导入sql文件和导出sql文件
  8. 【bzoj1507】[NOI2003]Editor
  9. bzoj 3670: [Noi2014]动物园
  10. 【体系结构】LGWR进程触发机制的理解