检查 Swarm 中的服务
当您已将 服务部署到您的群集后,您可以使用 Docker CLI 查看在群集中运行的服务详情。
如果您尚未操作,请打开终端并通过 SSH 连接到运行您管理节点的机器。例如,本教程使用一台名为
manager1的机器。运行
docker service inspect --pretty <SERVICE-ID>以易于阅读的格式显示服务详情。查看
helloworld服务的详细信息:[manager1]$ docker service inspect --pretty helloworld ID: 9uk4639qpg7npwf3fn2aasksr Name: helloworld Service Mode: REPLICATED Replicas: 1 Placement: UpdateConfig: Parallelism: 1 ContainerSpec: Image: alpine Args: ping docker.com Resources: Endpoint Mode: vip提示
要将服务详情以 JSON 格式返回,请在不带
--pretty标志的情况下运行相同的命令。[manager1]$ docker service inspect helloworld [ { "ID": "9uk4639qpg7npwf3fn2aasksr", "Version": { "Index": 418 }, "CreatedAt": "2016-06-16T21:57:11.622222327Z", "UpdatedAt": "2016-06-16T21:57:11.622222327Z", "Spec": { "Name": "helloworld", "TaskTemplate": { "ContainerSpec": { "Image": "alpine", "Args": [ "ping", "docker.com" ] }, "Resources": { "Limits": {}, "Reservations": {} }, "RestartPolicy": { "Condition": "any", "MaxAttempts": 0 }, "Placement": {} }, "Mode": { "Replicated": { "Replicas": 1 } }, "UpdateConfig": { "Parallelism": 1 }, "EndpointSpec": { "Mode": "vip" } }, "Endpoint": { "Spec": {} } } ]运行
docker service ps <SERVICE-ID>以查看哪些节点正在运行该服务:[manager1]$ docker service ps helloworld NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS helloworld.1.8p1vev3fq5zm0mi8g0as41w35 alpine worker2 Running Running 3 minutes在这种情况下,
helloworld服务的一个实例正在worker2节点上运行。您可能会看到该服务在您的管理器节点上运行。 默认情况下,Swarm中的管理器节点可以像工作节点一样执行任务。Swarm 还会显示服务任务的
DESIRED STATE和CURRENT STATE,以便您查看任务是否根据服务定义正常运行。在运行该任务的节点上执行
docker ps,以查看有关该任务容器的详细信息。提示
如果
helloworld运行在除您的管理节点之外的其他节点上, 您必须通过 SSH 连接到该节点。[worker2]$ docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES e609dde94e47 alpine:latest "ping docker.com" 3 minutes ago Up 3 minutes helloworld.1.8p1vev3fq5zm0mi8g0as41w35
后续步骤
接下来,您将更改在群集中运行的服务的规模。