zoukankan      html  css  js  c++  java
  • docker-swarm实战

    docker-swarm 简介

    docker-swarm是一个集群管理工具,主要有以下几个组件
    1 Swarm 主要负责集群的管理和编排工作
    2 Node节点,分为manager节点和worker节点
    3 Service是任务的定义,管理机或工作节点上执行
    4 Task是Service的实例,是容器运行的一组命令

    docker-swarm搭建

    准备两台机器,在一台机器上执行swarm初始化

    docker swarm init --advertise-addr 81.68.86.146
    

    会显示加入的token和地址端口

    docker swarm join --token SWMTKN-1-2ifek5rwyq0k1d4rhhcyxjrmijlbuxm27rfcvqtkoxdgqdgn4j-0epqxkqlixe1r8uvr47g69iox 81.68.86.146:2377
    

    在另一台机器上执行上述加入操作,之后执行查看命令,可以看到集群节点状态

    docker node list
    

    显示一下

    ID                            HOSTNAME            STATUS              AVAILABILITY        MANAGER STATUS      ENGINE VERSION
    axapk9ke3o47r3er3jeqilpgg *   VM-0-9-ubuntu       Ready               Active              Leader              19.03.6
    7ynq5qr8s8tn3j5vkr5ke19k0     instance-6nsdfhv9   Ready               Active                                  19.03.12
    

    docker-swarm service

    我们可以创建service服务,然后指定具体的副本数,docker会根据副本数将service生成指定数量的容器执行task,这些容器负载均衡分配到不同的节点上。我们先创建一个名为demo的service

    docker service create --name demo busybox sh -c "while true; do sleep 3600; done"
    

    上述命令创建了一个名为demo的service, 我们可以通过docker service list 查看服务列表

    docker service list
    

    可以看到服务列表, 存在名字为demo的服务

    ID                  NAME                MODE                REPLICAS            IMAGE               
    xr5psjjt0nvx        demo                replicated          1/1                 busybox:latest
    

    我们也可以通过docker ps 查看启动的容器
    通过如下命令可以查看service的详细信息

    docker service ps demo
    

    可以看到服务运行在哪个节点上
    接下来我们扩充下服务的数量

    docker service scale demo=5
    

    然后我们查看demo服务

    docker service ps demo
    

    会看到如下效果,启动了五个任务分别跑在不同的节点上

    ID                  NAME                IMAGE               NODE                DESIRED STATE       CURRENT STATE            ERROR               PORTS
    j78ygjp9r42k        demo.1              busybox:latest      VM-0-9-ubuntu       Running             Running 47 minutes ago                       
    9w7xifrhztki        demo.2              busybox:latest      instance-6nsdfhv9   Running             Running 19 seconds ago                       
    s15r73i10m43        demo.3              busybox:latest      instance-6nsdfhv9   Running             Running 19 seconds ago                       
    3ep3sjw50fro        demo.4              busybox:latest      instance-6nsdfhv9   Running             Running 19 seconds ago                       
    x80vmybr1dak        demo.5              busybox:latest      VM-0-9-ubuntu       Running             Running 22 seconds ago
    

    通过

    docker service list
    

    看到启动了五个容器,如果关闭其中一个,swarm会自动帮我们启动一个新的,保持数量为5个
    通过

    docker service rm demo
    

    删除demo服务,这样所有运行的容器都会被删除,执行docker service ps demo会看到demo服务被删除了。
    执行docker ps 看到容器也被删掉了

    service搭建wordpress

    利用service搭建wordpress,首先要创建一个共用网络,常见两个service,分别是mysql和wordpress

    docker network create -d overlay sw-net
    

    创建一个overlay类型的网络sw-net,这个网络可以保证多个宿主机之间通信
    之后查看网络列表

    docker network list
    

    可以看到我们新创建的网络。
    接下我们用service启动mysql服务

    docker service create --name mysql --env MYSQL_ROOT_PASSWORD=root --env MYSQL_DATABASE=wordpress --network sw-net  --mount type=volume,source=mysql-data,destination=/var/lib/mysql mysql:5.6
    

    注意–mount后的key和value对之间用逗号隔开,不能有空格
    命令运行后等待服务启动成功,根据docker service ps mysql 可以看到这个服务具体运行在哪个节点。
    接下来创建wordpress的service,和之前启动wordpress的容器类似

    docker service create --name wordpress -p 7080:80 --env WORDPRESS_DB_USESR=root --env WORDPRESS_DB_PASSWORD=root 
    --env WORDPRESS_DB_HOST=mysql:3306 --network sw-net  wordpress
    

    服务更新

    先将服务扩充为多个,这样保证服务稳定性

    docker service scale wordpress=5
    

    然后执行update

    docker service update --image wordpress:2.0  wordpress
    

    可以看到wordpress会在后台更新

    如果要更新端口则执行如下命令即可

    docker service update --publish-rm 8080:5000  --publish-add 8088:5000 wordpress
    

    上述命令将8080端口移除,换为8088端口

    感谢关注我的公众号

    wxgzh.jpg

  • 相关阅读:
    struct{} //长篇更新
    channel //长篇更新
    切片 //长篇更新
    引用
    核心:数据篇
    ARM指令解析
    arm寄存器解析
    Java-Selenium,获取下拉框中的每个选项的值,并随机选择某个选项
    log4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).
    eclipse安装springsource-tool-suite遇到的问题及解决方案
  • 原文地址:https://www.cnblogs.com/secondtonone1/p/14075182.html
Copyright © 2011-2022 走看看