码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • docker swarm安装指导


          SWARM部署DOCKER集群

    1. 简介............................................................................................................................ 3

    2. 部署准备..................................................................................................................... 3

    2.1. 系统组网图........................................................................................................ 3

    2.2. 系统业务逻辑流程.............................................................................................. 4

    2.3. 部署机器准备..................................................................................................... 4

    3. 部署步骤..................................................................................................................... 4

    3.1. DOCKER ENGINE的安装(本文中使用root用户进行安装).................................. 4

    3.2. 设置网络使DOCKER ENGINE支持远程访问,以下操作每个DOCKER SERVER都要做 4

    3.3. 配置swarm manager........................................................................................... 4

    3.4. 配置swarm node................................................................................................ 5

    3.5. 安装docker register, 登录到docker_machine服务器做如下操作.......................... 5

    3.6. 安装SHIPYARD,配置DOCKER SWARM MANAGE,登录到docker manager服务器做如下操作(通过配置文件来实现节点发现功能) 5

    4. 验证............................................................................................................................ 5

    5. 管理相关..................................................................................................................... 6

    5.1. SWARM 管理命令介绍........................................................................................ 6

    1.简介

          本文主要介绍如何用利用docker swarm+shipyard来实现一个docker集群的部署,该方案适用于测试和开发环境,要求docker engine版本>=1.12.0。Docker Engine在1.12.0版本后自带了Docker SWARM

          (注:后文中红色部分的字体请根据实际情况修改)

    2.部署准备 

    2.1.系统组网图

         

    模块

    作用

    SWARM MANAGE

    提供API接口将SHIPYARD发过来的请求,转发到对应的DOCKER SERVER,并返回结果给SHIPYARD

    DOCKER ENGINE

    提供 docker daemon进程来处理DOCKER SWARM MANAGE发过来的请求,并且返回结果

    SWARM NODE

    SWARM的WORKER节点主要用于为业务容器提供运行环境

    2.2.系统业务逻辑流程

       

    2.3. 部署机器准备

         本文中部署使用两台机器作为事例,如果要多台机器部署以此类推即可,下表格中的IP请根据具体情况修改(注:请保证下面的机器能访问外网,并且能使用DNS服务)

        

    机器名

    IP

    安装模块

    操作系统

    Docker_1

    1.1.1.1

    DOCKER ENGINE

    CENTOS7

    Docker_2

    1.1.1.2

    DOCKER ENGINE

    DOCKER REGISTRY

    CENTOS7

    Docker_3

    1.1.1.3

    DOCKER ENGINE

    CENTOS7

      3.部署步骤

    3.1.DOCKER ENGINE的安装(本文中使用root用户进行安装)

         参考:Install Docker Engine | Docker Docs,根据操作系统选择对应的安装方法

    3.2.设置网络使DOCKER ENGINE支持远程访问,以下操作每个DOCKER SERVER都要做

          1登录DOCKER服务器,执行

             cd /usr/lib/systemd/system

          2编辑docker.service文件,找到如下行做如下修改,并保存

             修改前:ExecStart=/usr/bin/dockerd

             修改后:ExecStart=/usr/bin/dockerd --insecure-registry [docker_registry_addr]

          3在防火墙中做如下配置,打开对2377端口的限制和对docker0端口的限制

             firewall-cmd --permanent --zone=public --add-port=2377/tcp

             firewall-cmd --permanent --zone=trusted --add-interface=docker0

             firewall-cmd --reload

    ​​​​​​​3.3.配置swarm manager

          登录到swarm manage的机器上,执行

                   docker swarm init --advertise-addr [swarm_manager_ip]
               执行后会得到类似如下信息
                 Swarm initialized: current node (dxn1zf6l61qsb1josjja83ngz) is now a manager.
     
    
                 To add a worker to this swarm, run the following command:
                   docker swarm join \
                   --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx14ie39trti4wxv-8vxv8rssmk743ojnwacrr2e7c \
                   192.168.99.100:2377
     
    
                To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.

    ​​​​​​​3.4.配置swarm node

          登录到docker-machine的机器上,执行上一步喜欢建SWARM MANAGER时候提示的加入NODE的语句

                   docker swarm join \
                   --token SWMTKN-1-49nj1cmql0jkz5s954yi3oex3nedyz0fb0xx14ie39trti4wxv-8vxv8rssmk743ojnwacrr2e7c \
                   192.168.99.100:2377
                如果记不到语句了可以使用如下命令来查看加入语句:
                   docker swarm join-token worker

           

    ​​​​​​​3.5.安装docker registry, 登录到docker_machine服务器做如下操作

          1 在要安装registry的机器上的/tmp/registry目录下增加配置文件config.yml内容如下(请严格按照格式缩进):

    log:

      fields:

        service: registry

    storage:

      cache:

        blobdescriptor: inmemory

      filesystem:

        rootdirectory: /var/lib/registry

      delete:

        enabled: true

    http:

      addr: :5000

      headers:

        X-Content-Type-Options: [nosniff]

    health:

      storagedriver:

        enabled: true

        interval: 10s

        threshold: 3     

          2 进入docker环境,输入如下命令

                  docker run -d -p 5000:5000 --restart=always --name registry -v /tmp/registry/config.yml:/etc/docker/registry/config.yml registry:2

    4.管理相关

    ​​​​​​​4.1.SWARM 管理命令介绍

          (参考URL:https://docs.docker.com/engine/swarm/swarm-tutorial/)

          docker swarm:  用于创建加入swarm node和swarm manager

          docker info:    查看当前SWARM集群信息

          docker node ls:查看当前SWARM 节点信息

          docker service:用于操作当前swarm中的service

               
    
  • 相关阅读:
    Node.js中的异步API
    openssl 生成自签名证书
    DOM核心编程
    Windows Server 2016 部署DNS
    bfs提高系列之陨石下落
    存储 MD5 的值应该用 VARCHAR 还是 CHAR
    攻击方法与工业控制系统安全
    【数据结构】栈和队列
    Jmeter工具下载并直连MySQL数据库
    数据库字段,逗号拼接存储,如何将其拆分查询
  • 原文地址:https://blog.csdn.net/LYX_WIN/article/details/133251593
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号