получение Обнаруженной ошибки задачи для некоторых изображений при создании службы Docker - PullRequest
0 голосов
/ 09 ноября 2018

Я пытаюсь создать службу Docker Swarm, но у меня странное поведение:

Для некоторых изображений это успешно, а для некоторых я получаю сообщение об ошибке:

docker service create nginx 89t21k3udf007pvl2ucvmdp9l overall progress: 1 out of 1 tasks 1/1: running [==================================================>] verify: Service converged -> Успех

docker service create hello-world 8hhdki32ypfwshh2wvijkkmvb overall progress: 0 out of 1 tasks 1/1: preparing [=================================> ] verify: Detected task failure -> Fail

Для справки: docker pull hello-world работает нормально.

У меня сложилось впечатление, что мы можем создавать сервисы для всех изображений, есть ли условия для этого? Я что-то упустил?

Примечание. Это основная часть, но я намерен создать сервис для образа локального реестра. Но после отладки обнаружил проблему на самом первом этапе, т. Е. Hello-world.

1 Ответ

0 голосов
/ 13 ноября 2018

Сбой, потому что контейнер, созданный из образа Docker hello-world, просто отображает сообщение, а затем завершает работу, и это происходит быстро.

И так как вы создали службу роя, он будет продолжать воссоздавать контейнер каждый раз, когда происходит сбой, что и ожидается, и поэтому служба, похоже, дает сбой.

Пожалуйста, посмотрите ниже сервисные журналы, и вы увидите, что контейнер продолжает создаваться заново:

[ ~]$ docker service create --name helloworld hello-world iilsd1yc706zgcdg35l8sdz3z
Since --detach=false was not specified, tasks will be created in the background.
In a future release, --detach=false will become the default.

[ ~]$ docker service logs helloworld  -f
helloworld.1.jxxnqzximfy7@    |
helloworld.1.zwyhf6x4cpdm@    |
helloworld.1.jxxnqzximfy7@    | Hello from Docker!
helloworld.1.zwyhf6x4cpdm@    | Hello from Docker!
helloworld.1.jxxnqzximfy7@    | This message shows that your installation appears to be working correctly.
helloworld.1.zwyhf6x4cpdm@    | This message shows that your installation appears to be working correctly.
helloworld.1.zwyhf6x4cpdm@   |
helloworld.1.jxxnqzximfy7@    |
helloworld.1.jxxnqzximfy7@    | To generate this message, Docker took the following steps:
helloworld.1.zwyhf6x4cpdm@    | To generate this message, Docker took the following steps:
helloworld.1.zwyhf6x4cpdm@    |  1. The Docker client contacted the Docker daemon.
helloworld.1.jxxnqzximfy7@    |  1. The Docker client contacted the Docker daemon.
helloworld.1.jxxnqzximfy7@    |  2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
helloworld.1.zwyhf6x4cpdm@    |  2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
helloworld.1.zwyhf6x4cpdm@    |     (amd64)
helloworld.1.jxxnqzximfy7@    |     (amd64)
helloworld.1.zwyhf6x4cpdm@   |  3. The Docker daemon created a new container from that image which runs the
helloworld.1.jxxnqzximfy7@    |  3. The Docker daemon created a new container from that image which runs the
helloworld.1.jxxnqzximfy7@    |     executable that produces the output you are currently reading.
helloworld.1.zwyhf6x4cpdm@    |     executable that produces the output you are currently reading.
helloworld.1.zwyhf6x4cpdm@    |  4. The Docker daemon streamed that output to the Docker client, which sent it
helloworld.1.jxxnqzximfy7@    |  4. The Docker daemon streamed that output to the Docker client, which sent it
helloworld.1.jxxnqzximfy7@    |     to your terminal.
helloworld.1.zwyhf6x4cpdm@    |     to your terminal.
helloworld.1.jxxnqzximfy7@    |
helloworld.1.jxxnqzximfy7@    | To try something more ambitious, you can run an Ubuntu container with:
helloworld.1.zwyhf6x4cpdm@    |
helloworld.1.zwyhf6x4cpdm@    | To try something more ambitious, you can run an Ubuntu container with:
helloworld.1.jxxnqzximfy7@    |  $ docker run -it ubuntu bash
helloworld.1.jxxnqzximfy7@    |
helloworld.1.zwyhf6x4cpdm@    |  $ docker run -it ubuntu bash
helloworld.1.jxxnqzximfy7@    | Share images, automate workflows, and more with a free Docker ID:
helloworld.1.jxxnqzximfy7@    |  https://hub.docker.com/
helloworld.1.zwyhf6x4cpdm@    |
helloworld.1.zwyhf6x4cpdm@    | Share images, automate workflows, and more with a free Docker ID:
helloworld.1.jxxnqzximfy7@    |
helloworld.1.zwyhf6x4cpdm@    |  https://hub.docker.com/
helloworld.1.zwyhf6x4cpdm@    |
helloworld.1.jxxnqzximfy7@    | For more examples and ideas, visit:
helloworld.1.jxxnqzximfy7@    |  https://docs.docker.com/get-started/
helloworld.1.zwyhf6x4cpdm@    | For more examples and ideas, visit:
helloworld.1.jxxnqzximfy7@    |
helloworld.1.zwyhf6x4cpdm@    |  https://docs.docker.com/get-started/
helloworld.1.zwyhf6x4cpdm@    |
helloworld.1.yw17ktyymrp6@    |
helloworld.1.yw17ktyymrp6@    | Hello from Docker!
helloworld.1.yw17ktyymrp6@    | This message shows that your installation appears to be working correctly.

Вам следует попробовать другой образ Docker, busybox, например:

[~]$ docker service create --name helloworld busybox:latest sh -c "while true; do echo Hello; sleep 2; done"
yjxzteshp7k2xf4aznj4l86s6
Since --detach=false was not specified, tasks will be created in the background.
In a future release, --detach=false will become the default.
[~]$ docker service ps helloworld --no-trunc
ID                          NAME                IMAGE                                                                                    NODE                              DESIRED STATE       CURRENT STATE          ERROR               PORTS
33xe78ekfjkmti8yahrcp5gug   helloworld.1        busybox:latest@sha256:2a03a6059f21e150ae84b0973863609494aad70f0a80eaeb64bddd8d92465812      Running             Running 1 second ago
[~]$ docker service logs -f helloworld
helloworld.1.33xe78ekfjkm@    | Hello
helloworld.1.33xe78ekfjkm@    | Hello
helloworld.1.33xe78ekfjkm@    | Hello
helloworld.1.33xe78ekfjkm@    | Hello
helloworld.1.33xe78ekfjkm@    | Hello
^C
...