首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
1
『中级篇』overlay网络和etcd实现多机的容器通信(31)
2
『中级篇』docker的数据持久化存储和数据共享(32)
3
『中级篇』docker的数据持久化存储和数据共享(33)
4
『中级篇』数据持久化之Data Volume(34)
5
『中级篇』数据持久化之bind Mounting(35)
6
『中级篇』docker 使用bind Mounting实战(36)
7
『中级篇』docker容器安装wordpress(37)
8
『中级篇』Docker Compose到底是什么(38)
9
『中级篇』Docker Compose的安装和基本使用(39)
10
『中级篇』Docker 水平扩展和负载均衡(40)
11
『中级篇』Docker compose 部署一个复杂的应用(41)
12
『中级篇』容器编排Docker Swarm介绍(42)
13
『中级篇』docker-swarm创建一个多节点集群(43)
14
『中级篇』play with docker 的使用(44)
15
『中级篇』docker-swarm中的Service创建维护和水平扩展(45)
16
『中级篇』在docker-swarm集群里通过serivce部署wordpress(46)
17
『中级篇』集群服务间通信之RoutingMesh(47)
18
『中级篇』RoutingMesh之Ingress负载均衡(48)
19
『中级篇』Docker-Stack部署wordpress(49)
20
『中级篇』Docker-Stack部署投票应用(50)
21
『中级篇』Docker-Secret管理和使用(51)
22
『中级篇』Docker service更新(52)
23
『中级篇』Docker的收费模式(53)
24
『中级篇』Docker-cloud介绍(54)
25
『中级篇』Docker Cloud自动构建 Docker image(55)
26
『中级篇』Docker企业版的在线免费体验(56)
27
『中级篇』docker企业版本地安装之UCP(57)
28
『中级篇』Kubenetes简介(60)

『中级篇』docker-swarm创建一个多节点集群(43)

docker Swarm是Docker官方提供的一款集群管理工具,其主要作用是把若干台Docker主机抽象为一个整体,并且通过一个入口统一管理这些Docker主机上的各种Docker资源。源码地址:https://github.com/limingios/docker中的No.5

创建3台虚拟机

还是通过vagrant + virtualbox的方式来创建

  • 源码文件夹
  • 查看创建虚拟机的源码
代码语言:javascript
复制
# -*- mode: ruby -*-
# vi: set ft=ruby :

Vagrant.require_version ">= 1.6.0"

boxes = [
    {
        :name => "swarm-manager",
        :mem => "1024",
        :cpu => "1"
    },
    {
        :name => "swarm-worker1",
        :mem => "1024",
        :cpu => "1"
    },
    {
        :name => "swarm-worker2",
        :mem => "1024",
        :cpu => "1"
    }
]

Vagrant.configure(2) do |config|

  config.vm.box = "centos/7"

  boxes.each do |opts|
      config.vm.define opts[:name] do |config|
        config.vm.hostname = opts[:name]
        config.vm.provider "vmware_fusion" do |v|
          v.vmx["memsize"] = opts[:mem]
          v.vmx["numvcpus"] = opts[:cpu]
        end

        config.vm.provider "virtualbox" do |v|
          v.customize ["modifyvm", :id, "--memory", opts[:mem]]
          v.customize ["modifyvm", :id, "--cpus", opts[:cpu]]
        end

        config.vm.network :private_network, type: "dhcp"
      end
  end

  config.vm.synced_folder "./labs", "/home/vagrant/labs"
  config.vm.provision "shell", privileged: true, path: "./setup.sh"

end
用SecureCRT连接着3个虚拟机
  • 查看每个虚拟机的ip地址
代码语言:javascript
复制
vagrant ssh swarm-manager
#swarm-manager的ip是172.28.128.3
ip a
代码语言:javascript
复制
vagrant ssh swarm-worker1
#swarm-worker1的ip是172.28.128.4
ip a
代码语言:javascript
复制
vagrant ssh swarm-worker2
#swarm-worker2的ip是172.28.128.5
ip a
创建docker-swarm集群
  1. swarm-manager 建立manager
代码语言:javascript
复制
sudo docker swarm init --help
 sudo docker swarm init --advertise-addr=172.28.128.3
  1. swarm-worker1 和 swam-worker2 连接manager
代码语言:javascript
复制
sudo service docker restart
docker swarm join --token SWMTKN-1-1vafvfucsur6iqd6ba5i2njty6djvzxnhwefsmar4sivcg8isi-dgm1aigtcu1rtotfc8y43j17m 172.28.128.3:2377
  1. swarm-manager 查看连接状态
代码语言:javascript
复制
docker node ls

个人网站:IT人故事会 idig8.com

PS:这样基本上通过docker-swarm完成集群管理。

下一篇
举报
领券