Команда docker не работает для конкретного пользователя - PullRequest
1 голос
/ 07 ноября 2019

Я пытаюсь выполнить команду "docker run hello-world" для двух разных пользователей. Он отлично работает для пользователя "ec2"

ec2-user@ip-172-31-17-83 ~]$ docker run hello-world

Hello from Docker!
This message shows that your installation appears to be working correctly.

To generate this message, Docker took the following steps:
 1. The Docker client contacted the Docker daemon.
 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
    (amd64)
 3. The Docker daemon created a new container from that image which runs the
    executable that produces the output you are currently reading.
 4. The Docker daemon streamed that output to the Docker client, which sent it
    to your terminal.

To try something more ambitious, you can run an Ubuntu container with:
 $ docker run -it ubuntu bash

Share images, automate workflows, and more with a free Docker ID:
 https://hub.docker.com/

For more examples and ideas, visit:
 https://docs.docker.com/get-started/

Но не для пользователя "gitlab-runner"

[ec2-user@ip-172-31-17-83 ~]$ sudo docker run hello-world --user=gitlab-runner
docker: Error response from daemon: OCI runtime create failed: container_linux.go:348: starting container process caused "exec: \"--user=gitlab-runner\": executable file not found in $PATH": unknown.

В чем может быть причина?

$ PATH для пользователя gitlab-runner

[ec2-user @ ip-172-31-17-83 ~] $ echo $ PATH --user = gitlab-runner / usr / local / bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/opt/aws/bin:/home/ec2-user/.local/bin:/home/ec2-user/bin--user = gitlab-runner [ec2-user @ ip-172-31-17-83 ~] $ докер docker: / usr / bin / docker / etc / docker /usr/share/man/man1/docker.1.gz [ec2-user @ ip-172-31-17-83 ~] $

1 Ответ

0 голосов
/ 07 ноября 2019

Все, что находится после имени изображения, интерпретируется как команда для запуска:

sudo docker run \
  hello-world \           # image name
  --user=gitlab-runner    # command to run inside the container

Если у вас есть какие-либо опции для docker run, они должны быть до имени изображения

sudo docker run \
  --user=gitlab-runner \  # set the user based off the container's /etc/passwd
  hello-world             # image name
                          # running the default command
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...