• docker~swarm搭建docker高可用集群


    回到目录

    Swarm概念

      Swarm是Docker公司推出的用来管理docker集群,它将一群Docker宿主机变成一个单一的,虚拟的主机。Swarm使用标准的Docker API接口作为其前端访问入口,换言之,各种形式的Docker Client(docker client in Go, docker_py, docker等)均可以直接与Swarm通信。Swarm几乎全部用go语言来完成开发,Swarm0.2发布,相比0.1版本,0.2版本增加了一个新的策略来调度集群中的容器,使得在可用的节点上传播它们,以及支持更多的Docker命令以及集群驱动。
      Swarm deamon只是一个调度器(Scheduler)加路由器(router),Swarm自己不运行容器,它只是接受docker客户端发送过来的请求,调度适合的节点来运行容器,这意味着,即使Swarm由于某些原因挂掉了,集群中的节点也会照常运行,当Swarm重新恢复运行之后,它会收集重建集群信息.

    Swarm结构图

    Swarm的基本命令

    docker node 用来显示集群的节点,默认建立时只有一个节点,当然也就谈不上高可用了,可以使用docker node --help来查看所有node参数

    集群初始化 docker swarm init 

    当已经被初始化后,就不能重新执行这个操作了,使用docker node ls 来查看刚建立的集群

    集群中的管理节点和工作节点功能图

    添加管理节点 docker swarm join

    Docker Swarm 命令中还需要添加一些选项:

    * join:表明一个新的节点将被添加进 Swarm

    * –manager:表明节点的性质(manager vs worker)

    * –listen-addr:让一个新添加的节点可以访问 Swarm 内的其他节点

    * 最后的参数就是第一管理节点的地址(即这一命令将被送到的那个节点)

    注意:由于 –auto-accept manager 选项会在 Swarm 初始化的过程中被提供,所以第二管理节点会被自动接受。如果没有这一选项,那么第二管理节点需要被第一管理节点手动接受。

    $ MANAGER2_IP=$(docker-machine ip manager2)
    docker-machine ssh manager2 docker swarm join --manager --listen-addr $MANAGER2_IP:2377 $MANAGER1_IP:2377
    

    Swarn部署时使用的脚本,来自网络

    下面是一小段用来创建 Docker 主机并部署 Swarm 的 Shell 脚本。当然了,管理/工作节点的数字都是可以随意改动的。
    注意:创建两个管理节点和两个工作节点,仅仅是用来作示范。在工业生产中,我们可能需要在集群里搭建 3 个管理节点和 5 个工作节点。

    # Define the number of managers/workers
    MANAGER=3
    WORKER=5
    
    # Create the Docker hosts
    for i in $(seq 1 $MANAGER); do docker-machine create --driver virtualbox manager$i; done
    for i in $(seq 1 $WORKER); do docker-machine create --driver virtualbox worker$i; done
    
    # Init the swarm
    docker-machine ssh manager1 docker swarm init --auto-accept manager --auto-accept worker --listen-addr $(docker-machine ip manager1):2377
    
    # Add additional manager(s)
    for i in $(seq 2 $MANAGER); do docker-machine ssh manager$i docker swarm join --manager --listen-addr $(docker-machine ip manager$i):2377 $(docker-machine ip manager1):2377; done
    
    # Add workers
    for i in $(seq 1 $WORKER); do docker-machine ssh worker$i docker swarm join --listen-addr $(docker-machine ip worker$i):2377 $(docker-machine ip manager1):2377; done

    对于上面文章中,只提到了集群,而没有谈到如何去使用,在建立集群后,服务的部署我们可以用

    docker stack deploy  -c test.yml test

    下面给出自己写的一个服务,版本3的

    version: "3"
    
    services:
      loggerapi:
        image: logger.api
        build:
          context: ./src/Logger.Api
          dockerfile: Dockerfile
        ports:
          - "5000:80"
        networks:
          - ingress
    
     loggermanager:
        image: logger.manager
        build:
          context: ./src/Logger.Manager
          dockerfile: Dockerfile
        ports:
          - "5050:80"
        networks:
          - ingress
    
    networks:
      ingress:

    这里有个服务要注意,服务的名称一定不能有点,如logger.manager这是错误的!

    来建立一个服务,同时可以使用docker service来查看已经运行的服务!

    还有一点要注意,yml在进行v3版后,不再支持build,也就是说,你需要先把镜像建立好才行!

    回到目录

  • 相关阅读:
    使用docker部署zabbix
    如何用好 IDEA ,Java 撸码效率至少提升 5 倍?
    getpass模块
    linux下利用nohup后台运行jar文件包程序
    Spring Cloud 与 Dubbo 区别
    git 打标签并推送tag到托管服务器
    git-stash用法小结
    git推送本地分支到远程分支
    Git dev分支合并到master分支完美实战
    IntelliJ远程调试教程
  • 原文地址:https://www.cnblogs.com/lori/p/7243324.html
Copyright © 2020-2023  润新知