Запуск run docker из cloud-init неправильно добавляет префикс docker.io к имени образа

Я запускаю сервер GCE с файлом cloudinit, который вызывает образ докера. При запуске вытащить образ докера не удается, но если я запускаю ту же службу при входе в систему, она завершается успешно. Я хотел бы, чтобы он работал при запуске.

Глядя на журналы службы, кажется, что он неправильно ставит префикс docker pull с docker.io и поэтому не выполняет задание.

Могу ли я что-то сделать, чтобы предотвратить это? Возможно, мне нужно подождать или проверить, загружается ли что-то еще, прежде чем пытаться вытащить докер?

Вот мой файл инициализации облака:

#cloud-config

users:
- name: shinyuser
  uid: 2000

write_files:
- path: /etc/systemd/system/shinyserver.service
  permissions: 0644
  owner: root
  content: |
    [Unit]
    Description=Shiny server

    [Service]
    ExecStart=/usr/bin/docker run --name=vdshinyserver -p 80:3838 -v /home/shinyuser/shinyapps/:/srv/shiny-server/ -v /home/shinyuser/srv/shinylog/:/var/log/ rocker/shiny
    ExecStop=/usr/bin/docker stop vdshinyserver

runcmd:
- systemctl daemon-reload
- systemctl start shinyserver.service 

И вот логи:

mark@xxxshiny ~ $ sudo journalctl -u shinyserver
-- Logs begin at Wed 2016-10-05 08:39:06 UTC, end at Wed 2016-10-05 08:39:46 UTC. --
Oct 05 08:39:11 xxxshiny docker[1016]: Unable to find image 'rocker/shiny:latest' locally
Oct 05 08:39:26 xxxshiny docker[1016]: Pulling repository docker.io/rocker/shiny
Oct 05 08:39:31 xxxshiny docker[1016]: /usr/bin/docker: Tag latest not found in repository docker.io/rocker/shiny.
Oct 05 08:39:31 xxxshiny docker[1016]: See '/usr/bin/docker run --help'.
Oct 05 08:39:31 xxxshiny docker[1045]: Error response from daemon: No such container: vdshinyserver

mark@visit-dubai-shiny ~ $ sudo systemctl start shinyserver.service
mark@visit-dubai-shiny ~ $ sudo journalctl -u shinyserver
...
Oct 05 08:42:22 xxxshiny docker[1117]: Unable to find image 'rocker/shiny:latest' locally
Oct 05 08:42:23 xxxshiny docker[1117]: latest: Pulling from rocker/shiny
Oct 05 08:42:23 xxxshiny docker[1117]: a84f66826a7f: Pulling fs layer
Oct 05 08:42:23 xxxshiny docker[1117]: aaf7c0da390d: Pulling fs layer
...etc...

person MarkeD    schedule 05.10.2016    source источник


Ответы (1)


Я отредактировал свой cloudinit, чтобы он соответствовал документации Docker, чтобы включить требование docker.service в файл, и теперь он работает:

#cloud-config

users:
- name: shinyuser
  uid: 2000

write_files:
- path: /etc/systemd/system/shinyserver.service
  permissions: 0644
  owner: root
  content: |
    [Unit]
    Description=VisitDubai Shiny server for reporting
    Requires=docker.service
    After=docker.service

    [Service]
    Restart=always
    ExecStart=/usr/bin/docker run --name=vdshinyserver -p 80:3838 -v /home/shinyuser/shinyapps/:/srv/shiny-server/ -v /home/shinyuser/srv/shinylog/:/var/log/ rocker/shiny
    ExecStop=/usr/bin/docker stop vdshinyserver
person MarkeD    schedule 05.10.2016
comment
Я также добавил Requires и After, оказалось, что Restart=always важен. - person Matthew Warman; 26.07.2017