当前位置:   article > 正文

docker privileged作用_「实战篇」开源项目docker化运维部署-借助dockerSwarm搭建集群部署(九)...

swarm privileged

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

7365f3987f56363c16e47adee9af2715.png

一起在说说docker swarm

swarm 是docker的三剑客一员,之前都说过了,可以看中级和高级啊 。
  1. docker machine 容器服务
  2. docker compose 脚本服务
  3. docker swarm 容器集群技术

61a31b178a865271ddaf85086cddc057.png
  • 去中心化的设计
Swarm Manager 也承担worker节点的作用。
Swarm Worker 运行容器部署项目

0e83a8a87bd3062dab5c95d7bb983e7f.png
Swarm是没有中心节点的,挂到其中一个其他是不会挂掉的。Swarm Manager 如果master挂了,立马选举一个新的master。
  • 创建集群环境
首先机器已经安装了docker环境。
docker swarm init
  • 加入swarm集群
  1. #加入到manager中
  2. docker swarm join-token manager
  3. #加入到worker中
  4. docker swarm join-token worker

环境搭建

应用IP地址服务配置安装应用安装方式docker-swarm-manager1192.168.66.100docker-swarm-manager1单核 2g内存docker-swarm-manager1dockerdocker-swarm-manager2192.168.66.101docker-swarm-manager2单核 2g内存docker-swarm-manager2dockerdocker-swarm-node1192.168.66.102docker-swarm-node1单核 2g内存docker-swarm-node1dockerdocker-swarm-node2192.168.66.103docker-swarm-node2单核 2g内存docker-swarm-node2docker

67baa56ce0df735ce5f459ec51cc2cc8.png

docker swarm环境

一共4个节点,2个manager节点,2个work节点,manager不光是管理,而且也干活,说白了一共4个干活的节点。
创建docker swarm集群
  1. su -
  2. #密码vagrant
  3. docker swarm init
报错注意:如果你在新建集群时遇到双网卡情况,可以指定使用哪个 IP,例如上面的例子会有可能遇到下面的错误。
  1. Error response from daemon: could not choose an IP address to
  2. advertise since this system has multiple addresses on different
  3. interfaces (10.0.2.15 on enp0s3 and 192.168.66.100 on enp0s8)
  4. - specify one with --advertise-addr
再次创建docker swarm集群192.168.66.100
  1. docker swarm init --advertise-addr 192.168.66.100 --listen-addr 192.168.66.100:2377
  2. docker swarm join-token manager

86045b4a4dbf1bb8f68fc06525a38007.png

a77a09512647f3ec792f4f485b087878.png
再次创建docker swarm集群192.168.66.101
当前节点以manager的身份加入swarm集群
docker swarm join --token SWMTKN-1-4itumtscktomolcau8a8cte98erjn2420fy2oyj18ujuvxkkzx-9qutkvpzk87chtr4pv8770mcb 192.168.66.100:2377

021f815288d5ad8e4665815dfc91b89b.png
再次创建docker swarm集群192.168.66.102
当前节点以worker的身份加入swarm集群
docker swarm join --token SWMTKN-1-4itumtscktomolcau8a8cte98erjn2420fy2oyj18ujuvxkkzx-f2dlt8g3hg86gyc9x6esewtwl 192.168.66.100:2377

da8eaaa9e46319d73d3f176059a01e95.png
再次创建docker swarm集群192.168.66.103
当前节点以worker的身份加入swarm集群
docker swarm join --token SWMTKN-1-4itumtscktomolcau8a8cte98erjn2420fy2oyj18ujuvxkkzx-f2dlt8g3hg86gyc9x6esewtwl 192.168.66.100:2377

abc9df5f0f8b49c6742581a22a72d139.png

查看swarm集群

只能在manager节点内执行
leader挂掉后,reachable就可以管理集群了。
docker node ls

77dd4940a71cfcf4c57ab07e39bb6307.png

查看swarm集群的网络

只能在manager节点内执行
docker network ls

036d95b2909b2a9bcc5514e1ba404d5f.png

创建容器间的共享网络

只能在manager节点内执行
  1. docker network create -d overlay --attachable swarm_test
  2. docker network ls

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

2db32ab3ae6176e29d1719c48aa9df0f.png

创建5个pxc容器

  • 192.168.66.100
创建2个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。
  1. docker volume create v1
  2. docker volume create backup1
  3. #增加域名解析
  4. echo "nameserver 8.8.8.8" | tee /etc/resolv.conf > /dev/null
  5. sudo curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://b81aace9.m.daocloud.io
  6. sudo systemctl restart docker
  7. docker run -d -p 3306:3306 --net=swarm_test
  8. --name=node1
  9. -e CLUSTER_NAME=PXC
  10. -e MYSQL_ROOT_PASSWORD=a123456
  11. -e XTRABACKUP_PASSWORD=a123456
  12. -v v1:/var/lib/mysql
  13. --privileged
  14. -v backup1:/data
  15. percona/percona-xtradb-cluster
  16. docker ps

42e7962ca3a9cd9f801f5e6adae36681.png

fa00f39a2b145b4162c28d42021f4dd4.png

2efd6a5c5874359d185def748fe45f0b.png
  1. docker volume create v2
  2. docker run -d -p 3307:3306 --net=swarm_test
  3. --name=node2
  4. -e CLUSTER_NAME=PXC
  5. -e MYSQL_ROOT_PASSWORD=a123456
  6. -e XTRABACKUP_PASSWORD=a123456
  7. -v v2:/var/lib/mysql
  8. --privileged
  9. -v backup1:/data
  10. -e CLUSTER_JOIN=node1
  11. percona/percona-xtradb-cluster
  12. docker ps

c2e500f19c8eb3ccaf4d68c89b44f133.png
  • 192.168.66.101
创建1个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。
  1. docker volume create v3
  2. docker volume create backup3
  3. docker run -d -p 3307:3306 --net=swarm_test
  4. --name=node3
  5. -e CLUSTER_NAME=PXC
  6. -e MYSQL_ROOT_PASSWORD=a123456
  7. -e XTRABACKUP_PASSWORD=a123456
  8. -v v3:/var/lib/mysql
  9. --privileged
  10. -v backup3:/data
  11. -e CLUSTER_JOIN=node1
  12. percona/percona-xtradb-cluster
  13. docker ps

4160eb4426321ad15c6f0f1f4946553a.png
  • 192.168.66.102
创建1个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。
  1. docker volume create v4
  2. docker volume create backup4
  3. docker run -d -p 3307:3306 --net=swarm_test
  4. --name=node4
  5. -e CLUSTER_NAME=PXC
  6. -e MYSQL_ROOT_PASSWORD=a123456
  7. -e XTRABACKUP_PASSWORD=a123456
  8. -v v4:/var/lib/mysql
  9. --privileged
  10. -v backup4:/data
  11. -e CLUSTER_JOIN=node1
  12. percona/percona-xtradb-cluster
  13. docker ps
  • 192.168.66.103
创建1个容器。之前也说过如何创建,最为重要的是共享网络一定要使用swarm的共享网络。
  1. docker volume create v4
  2. docker volume create backup4
  3. docker run -d -p 3307:3306 --net=swarm_test
  4. --name=node4
  5. -e CLUSTER_NAME=PXC
  6. -e MYSQL_ROOT_PASSWORD=a123456
  7. -e XTRABACKUP_PASSWORD=a123456
  8. -v v4:/var/lib/mysql
  9. --privileged
  10. -v backup4:/data
  11. -e CLUSTER_JOIN=node1
  12. percona/percona-xtradb-cluster
  13. docker ps

52dd4ad102b0dc6e8cde1e81e6995989.png

4143d1f74aba0a7d1cf9f9e55ae0c02d.png

容器集群

在这个示意图里面,画了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容器内的数量。

98a5c5f70615524a93dfa00ef5eabb9b.png

dbb3f2e767e5bcc0fb6de623e9a5593e.png

容器集群适合的场景

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

4ac7d8566017064d25d9c264899c693c.png


image.png

退出Swarm集群

  1. #Manager退出必须加--force
  2. docker swarm leave --force

删除节点

  1. service docker stop
  2. #Manager节点需要先降级
  3. docker node demoted <nodeID>
  4. docker node rm <nodeID>
  5. docker network

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/空白诗007/article/detail/944505
推荐阅读
相关标签
  

闽ICP备14008679号