2 votes

Je ne peux pas déployer un service Docker Swarm en utilisant une image basée sur ubuntu.

Je suis un débutant dans Docker/Docker Swarm et je veux créer un service mosquitto personnalisé sur Swarm. J'ai créé une image personnalisée de mosquitto lcsf/mosquitto3 d'ubuntu:latest, puis j'ai ajouté quelques outils (ping, ipconfig). Je peux faire fonctionner un seul conteneur avec docker run y /bin/bash mais je n'arrive pas à créer un service Swarm avec cette image. Le service n'est pas créé avec succès. Il y a quelques résultats ci-dessous.

Dockerfile :

FROM ubuntu:latest RUN apt-get -y update RUN apt-get install -y mosquitto mosquitto-clients EXPOSE 80 443 1883 8083 8883

Docker service create output :

overall progress: 0 out of 1 tasks 1/1: preparing [========> ] verify: Detected task failure

Cette sortie est affichée en boucle, puis je l'arrête en utilisant ctrl+c, le service est créé, mais ne s'exécute pas, avec 0/1 répliques.

Docker service ps mqtt (mon nom personnalisé) output, il y a 3 noeuds.

ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS llqr0gysz4bj mqtt.1 lcsf/mosquitto3:latest Docker02 Ready Ready 2 seconds ago kcwfqovyn2mp \_ mqtt.1 lcsf/mosquitto3:latest Docker03 Shutdown Complete 2 seconds ago ruisy599nbt4 \_ mqtt.1 lcsf/mosquitto3:latest Docker03 Shutdown Complete 7 seconds ago xg1lib5x8vt9 \_ mqtt.1 lcsf/mosquitto3:latest Docker02 Shutdown Complete 13 seconds ago fgm9wu25t0lj \_ mqtt.1 lcsf/mosquitto3:latest Docker03 Shutdown Complete 18 seconds ago

Voilà, j'espère que quelqu'un pourra m'aider. Merci d'avance et désolé pour mon anglais et mes compétences en Stack Overflow.

MISE À JOUR N° 1

Sortie de journalctl -f -n10 après avoir essayé de créer le service :

Sep 25 09:01:03 Docker01 dockerd[1230]: time="2017-09-25T09:01:03.692391553-04:00" level=info msg="Node join event for Docker02-a9b6d39043d3/192.168.222.51" Sep 25 09:01:15 Docker01 systemd-udevd[31966]: Could not generate persistent MAC address for veth8e5ebcb: No such file or directory Sep 25 09:01:15 Docker01 systemd-udevd[31967]: Could not generate persistent MAC address for vethaf2978b: No such file or directory Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered blocking state Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered disabled state Sep 25 09:01:15 Docker01 kernel: device vethaf2978b entered promiscuous mode Sep 25 09:01:15 Docker01 kernel: IPv6: ADDRCONF(NETDEV_UP): vethaf2978b: link is not ready Sep 25 09:01:15 Docker01 kernel: eth0: renamed from veth8e5ebcb Sep 25 09:01:15 Docker01 kernel: IPv6: ADDRCONF(NETDEV_CHANGE): vethaf2978b: link becomes ready Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered blocking state Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered forwarding state Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered disabled state Sep 25 09:01:15 Docker01 kernel: veth8e5ebcb: renamed from eth0 Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered disabled state Sep 25 09:01:15 Docker01 kernel: device vethaf2978b left promiscuous mode Sep 25 09:01:15 Docker01 kernel: docker0: port 1(vethaf2978b) entered disabled state Sep 25 09:01:33 Docker01 dockerd[1230]: time="2017-09-25T09:01:33.693508463-04:00" level=info msg="Node join event for Docker03-f71a448c54c7/192.168.222.52" Sep 25 09:01:46 Docker01 dockerd[1230]: time="2017-09-25T09:01:46.541311475-04:00" level=info msg="Node join event for Docker02-a9b6d39043d3/192.168.222.51" Sep 25 09:01:57 Docker01 dockerd[1230]: sync duration of 3.001217113s, expected less than 1s Sep 25 09:02:03 Docker01 dockerd[1230]: time="2017-09-25T09:02:03.694876667-04:00" level=info msg="Node join event for Docker03-f71a448c54c7/192.168.222.52" Sep 25 09:02:33 Docker01 dockerd[1230]: time="2017-09-25T09:02:33.695993259-04:00" level=info msg="Node join event for Docker03-f71a448c54c7/192.168.222.52"

MISE À JOUR N° 2

Il s'agit de la sortie de docker service ps --no-trunc mqtt commande

ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS bour693j8jbbrt799fz0nkpwr mqtt.1 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker03 Ready Ready 4 seconds ago wro6254cs94gkijs8s4v9cvim \_ mqtt.1 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker03 Shutdown Complete 4 seconds ago 7vgx2mehaxki2p680fesn5jww \_ mqtt.1 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker03 Shutdown Complete 10 seconds ago 52hv6da6mj72s64po3hze4ham \_ mqtt.1 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker03 Shutdown Complete 15 seconds ago e3s383vtg0idw8ryxwh2y3gmu \_ mqtt.1 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker03 Shutdown Complete 21 seconds ago 90i30f3riwka8xs187xi7uxt2 mqtt.2 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker02 Ready Ready less than a second ago p2lzd04tinjdjkwkr26umlh9a \_ mqtt.2 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker02 Shutdown Complete less than a second ago q8awoj8uu7gad6hvonhl4t9f1 \_ mqtt.2 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker02 Shutdown Complete 6 seconds ago 1fuqt0et7vw1vntd8p62jiiut \_ mqtt.2 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker02 Shutdown Complete 11 seconds ago k3vlusok792zw0v3yddxqlmg3 \_ mqtt.2 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker02 Shutdown Complete 17 seconds ago i4tywshqv4pxsyz5tz0z0evkz mqtt.3 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker01 Ready Ready less than a second ago 44ee4iqqpkeome4lokx9ykmbo \_ mqtt.3 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker01 Shutdown Complete less than a second ago kdx273e9fkpqkafztif1dz35q \_ mqtt.3 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker01 Shutdown Complete 6 seconds ago l2oewfnwbkia94r6rifbcfi4h \_ mqtt.3 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker01 Shutdown Complete 11 seconds ago dyekgkd0swsualssw4dtvk681 \_ mqtt.3 lcsf/mosquitto3:latest@sha256:beca44e5f916d08730dd19d9d10dd2dcbd3502866f69316806a63bc094a179a9 Docker01 Shutdown Complete 17 seconds ago

3voto

Tarun Lalwani Points 75641

Le problème vient de votre dockerfile. Vous exécutez une commande bash sur un service swarm. Vous devez exécuter une commande qui n'existe pas

FROM ubuntu:latest
RUN apt-get -y update
RUN apt-get install -y mosquitto mosquitto-clients
EXPOSE 80 443 1883 8083 8883
CMD ["tail", "-f", "/dev/null"]

Il s'agit d'une commande tail infinie, qui permet de s'assurer que votre conteneur ne se termine pas. Exécuter une commande dans une image qui ne demande pas d'entrée utilisateur lors du déploiement sur swarm.

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X