docker swarm常用命令

1、初始化Swarm集群

用于初始化一个Swarm集群,并将当前节点设置为Manager节点。

用法:docker swarm init --advertise-addr <Manager节点IP>

docker swarm init --advertise-addr 192.168.1.100

这会将当前节点初始化为Swarm集群的管理节点,并向其他节点广播IP 192.168.1.100。

2、将Worker节点加入Swarm集群

2.1 获取加入Swarm集群的工作节点令牌

docker swarm join-token worker

2.2获取加入Swarm集群的管理节点令牌

docker swarm join-token manager

2.3将一个Worker节点加入到Swarm集群

用法:docker swarm join --token <token> <Manager节点IP>:2377

docker swarm join --token SWMTKN-1-3t23f5f-vvjqz9sdgxlb12 192.168.1.100:2377

3、看节点状态

用法:docker node ls

docker node ls

更新节点的状态

用来更新Swarm集群中节点的可用性状态。

用法:docker node update --availability <availability> <node-name>

docker node update --availability drain worker-node-1

将worker-node-1节点设置为Drain状态,所有任务将被迁移到其他节点。

4、创建Swarm服务

用于创建一个新的Swarm服务。

用法:docker service create --name <service-name> --replicas <replicas> -p <port> <image>

docker service create --name web-service --replicas 3 -p 8080:80 nginx

使用nginx镜像创建一个名为web-service的服务,并将其副本数设置为3,映射容器的80端口到主机的8080端口。

5、查看服务

列出当前Swarm集群中所有的服务。

用法:docker service ls

docker service ls

6、查看服务的详细信息

用于查看特定服务的任务(容器)状态。

用法:docker service ps <service-name>

docker service ps web-service

7、更新服务

用于更新已有服务的配置,如镜像、端口、副本数等。

用法:docker service update --image <image> --replicas <replicas> <service-name>

docker service update --image nginx:latest --replicas 5 web-service

将web-service服务的镜像更新为nginx:latest,并将副本数扩展为5。

8、扩展或缩减服务副本数

用于动态调整服务的副本数。

用法:docker service scale <service-name>=<replicas>

docker service scale web-service=2 #web-service的副本数扩展到2

docker service ls

9、删除服务

用于删除Swarm中的服务。

用法:docker service rm <service-name>

docker service rm web-service #删除名为web-service的服务

10、查看Swarm集群的状态

docker info该命令提供有关Docker引擎的详细信息,包括Swarm集群的状态。

docker info

11、监控Swarm的日志

用于查看特定服务的日志。

用法:docker service logs <service-name>

docker service logs web-service显示web-service服务的容器日志

相关推荐
callJJ1 分钟前
Spring AI 文本聊天模型完全指南:ChatModel 与 ChatClient
java·大数据·人工智能·spring·spring ai·聊天模型
CBeann2 分钟前
企业级规则引擎落地实战:动态脚本引擎 QLExpress ,真香!
java·ai·大模型·规则引擎·qlexpress·大厂实战项目
懈尘2 分钟前
从 Java 1.7 到 Java 21:逐版本深入解析新特性与平台演进
java·开发语言
亓才孓3 分钟前
[Maven]Maven基础
java·maven
hello 早上好7 分钟前
05_Java 类加载过程
java·开发语言
echoVic20 分钟前
多模型支持的架构设计:如何集成 10+ AI 模型
java·javascript
橙露22 分钟前
Java并发编程进阶:线程池原理、参数配置与死锁避免实战
java·开发语言
echoVic23 分钟前
AI Agent 安全权限设计:blade-code 的 5 种权限模式与三级控制
java·javascript
PPPPickup26 分钟前
easymall---图片上传以及图片展示
java
历程里程碑28 分钟前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法