docker service create doesn't find image

When I run docker service create –mode global foo myrepo/foo-img:0.1, it works in that it starts the service, but if foo-img:0.1 does not exist on a node in the swarm, that node emits the following error:

<containerid>   \_ foo    myrepo/foo:0.1  <snip>  "No such image: myrepo/foo-img:0.1"

If I pull myrepo/foo-img:0.1 on each node then it works fine.

  • Kubernetes 1.2alpha8 AWS Container Registry Integration
  • Docker image format
  • How to use the forever CLI in Docker?
  • Spark cluster mode on Mesos: how to pass configuration to executor?
  • run docker Rstudio server without root?
  • Where exactly, are files in docker container stored on the host machine
  • Is there a workaround for this other than pulling the image on each node in the swarm?

  • Using AWS EFS with Docker
  • Ctrl-p and Ctrl-n behaving unexpectedly under Docker
  • How to quickly switch between docker environments for development?
  • How to create dynamic indexes in Kibana
  • Dockerized mongodb using mongoimport imports json array as item
  • Disk out of space on Azure Web app on Linux
  • One Solution collect form web for “docker service create doesn't find image”

    The answer is actually pretty simple. Use the--with-registry-auth parameter. This parameter uses the same authentication that is used for your current session. So, to make this work you simply:

    # docker login -u xxx -pass yyy https://myrepo.com
    # service create --with-registry-auth foo myrepo.com/foo-img:0.1
    

    Assuming that you successfully logged in, the service will pull the image from the repo to each node as needed. Not sure exactly what happens behind the scenes, but it works for deploying to all nodes currently in the cluster! Thanks to the help from the folks at github/docker!

    Docker will be the best open platform for developers and sysadmins to build, ship, and run distributed applications.