swarm使用

server1 2 3 安装好docker

docker network rm mac_net1  删掉没用网络

server1

docker swarm init

server2 3

docker swarm join --token SWMTKN-1-09trdon7fqn41f2n9y21ce47jnt4e8b63quqvubrnqfiy470eg-cxodahazph6br1gwm7gzztucq 172.25.11.1:2377

server1

docker node ls

[root@server1 ~]# docker node ls
ID                            HOSTNAME              STATUS              AVAILABILITY        MANAGER STATUS      ENGINE VERSION
39zp7zw06n1rslzvtsxviqjnq *   server1.example.com   Ready               Active              Leader              18.06.1-ce
hb4j7x1yu4a40ahtcocn5w7li     server2               Ready               Active                                  18.06.1-ce
tzhpszakws2hkgwplg9w6cvlw     server3               Ready               Active                                  18.06.1-ce

 

server1

 

自建网络系统可以解析

docker network create -d overlay my_net1

docker service create --name web --network my_net1 --publish 80:80 --replicas 30 nginx

下面是使用自代网桥

docker service create --name web   --publish 80:80 --replicas 3 nginx

[root@server1 ~]# docker service ls
ID                  NAME                MODE                REPLICAS            IMAGE               PORTS
vxrdx3kum3yp        web                 replicated          3/3                 nginx:latest        *:80->80/tcp

yum install -y bridge-utils

[root@server1 ~]# brctl show
bridge name    bridge id        STP enabled    interfaces
docker0        8000.024204e7493f    no        veth0f01b5c
                            vethe3b9c72
                            vethe5e8102
docker_gwbridge        8000.0242c57bf5a2    no        veth26d89ae
                            vetha92f97b

server 1 2 3 写文件

echo web1>index.html

docker  cp index.html    ID号:/usr/share/nginx/html

docker service scale web=6 拉申六个容器

 

for i in {1..10};do curl 172.25.11.1;done

[root@server1 ~]# for i in {1..10};do curl 172.25.11.1;done
web6
web1
web3
web2
web5
web4
web6
web1
web3
web2

 

加入监控server1

docker load -i visualizer.tar

docker service create --name=viz --publish=8080:8080/tcp --constraint=node.role==manager --mount=type=bind,src=/var/run/docker.sock,dst=/var/run/docker.sock dockersamples/visualizer

172.25.11.1:8080

docker service rm web

版本更新

docker save rhel7:v1 > rhel7.tar

每个节点都需要  但是如果有自己的仓库就不要了,仓库建立之前博客有

 docker load -i rhel7.tar

server1

docker service update  --image rhel7:v1 --update-delay 5s  --update-parallelism 5  web

[root@server1 ~]# docker service update  --image rhel7:v1 --update-delay 5s  --update-parallelism 5  web
image rhel7:v1 could not be accessed on a registry to record
its digest. Each node will access rhel7:v1 independently,
possibly leading to different nodes running different
versions of the image.

web
overall progress: 6 out of 6 tasks
1/6: running   
2/6: running   
3/6: running   
4/6: running   
5/6: running   
6/6: running   
verify: Service converged

每隔5s更新一次 每次更新5个

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker Swarm是Docker的原生集群管理工具,可以用于在多个主机上运行和管理容器。Dockerfile是一种用于定义Docker镜像构建过程的文本文件。 使用Docker Swarm时,可以使用Dockerfile创建镜像,但其实创建镜像的过程与在单个主机上创建镜像的过程非常相似。主要的区别是,在Swarm中创建的镜像将会在整个集群中被使用,而非仅限于单个主机。 首先,在Swarm集群的主节点上创建一个Dockerfile,该文件包含了构建镜像的指令和配置。以一个简单的Node.js应用为例,可以定义如下的Dockerfile: ``` FROM node:14-alpine WORKDIR /app COPY package*.json ./ RUN npm install COPY . . EXPOSE 3000 CMD [ "npm", "start" ] ``` 然后,在主节点的终端中,使用`docker build`命令来构建镜像。例如,使用以下命令创建一个名为`my-app`的镜像: ``` docker build -t my-app . ``` 接下来,使用`docker push`命令将构建好的镜像推送到Docker镜像仓库。例如,可以推送到Docker Hub: ``` docker push username/my-app ``` 最后,在Swarm集群的其他节点上使用`docker service`命令来创建服务,并使用先前构建的镜像作为服务的副本。例如,使用以下命令创建一个名为`my-app`的服务: ``` docker service create --name my-app --replicas 3 username/my-app ``` 这将在集群的多个节点上运行三个容器的副本,以提供高可用性和负载均衡的服务。 通过以上步骤,我们可以使用Dockerfile在Docker Swarm集群中创建镜像,并在集群中运行多个容器的副本来提供服务。这种方式使得应用程序可以更加灵活地在集群中运行,并可以根据需要进行扩展和管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值