docker service scale
| 描述 | 扩展一个或多个复制服务 |
|---|---|
| 用法 | docker service scale SERVICE=REPLICAS [SERVICE=REPLICAS...] |
Swarm 此命令适用于 Swarm 调度器。
描述
scale 命令允许您将一个或多个副本服务向上或向下扩展到所需的副本数量。此命令不能应用于全局模式的服务。该命令会立即返回,但服务的实际扩展可能需要一些时间。若要在保持服务在集群中处于活动状态的同时停止服务的所有副本,您可以将扩展数量设置为 0。
注意
这是一个集群管理命令,必须在 Swarm 管理节点上执行。要了解管理节点和工作节点,请参阅文档中的Swarm 模式部分。
选项
| 选项 | 默认 | 描述 |
|---|---|---|
-d, --detach | API 1.29+ 立即退出而不是等待服务收敛 |
示例
扩缩单个服务
以下命令将 "frontend" 服务扩展为 50 个任务。
$ docker service scale frontend=50
frontend scaled to 50
以下命令尝试将全局服务扩展到 10 个任务,并返回错误。
$ docker service create --mode global --name backend backend:latest
b4g08uwuairexjub6ome6usqh
$ docker service scale backend=10
backend: scale can only be used with replicated or replicated-job mode
紧接着,运行 docker service ls,以查看副本的实际数量。
$ docker service ls --filter name=frontend
ID NAME MODE REPLICAS IMAGE
3pr5mlvu3fh9 frontend replicated 15/50 nginx:alpine
您也可以使用
docker service update
命令来扩展服务。以下命令是等效的:
$ docker service scale frontend=50
$ docker service update --replicas=50 frontend
扩展多个服务
docker service scale 命令允许您一次性为多个服务设置所需的任务数量。以下示例同时扩缩容后端和前端服务:
$ docker service scale backend=3 frontend=5
backend scaled to 3
frontend scaled to 5
$ docker service ls
ID NAME MODE REPLICAS IMAGE
3pr5mlvu3fh9 frontend replicated 5/5 nginx:alpine
74nzcxxjv6fq backend replicated 3/3 redis:7.4.1