将Docker映像内的用户切换为非root用户


79

我正在尝试将用户切换到tomcat7用户,以设置SSH证书。

当我这样做时su tomcat7,什么也没发生。

whoami 做完后仍然发根 su tomcat7

这样做more /etc/passwd,我得到以下结果,清楚地表明存在tomcat7用户:

root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/bin/sh
bin:x:2:2:bin:/bin:/bin/sh
sys:x:3:3:sys:/dev:/bin/sh
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/bin/sh
man:x:6:12:man:/var/cache/man:/bin/sh
lp:x:7:7:lp:/var/spool/lpd:/bin/sh
mail:x:8:8:mail:/var/mail:/bin/sh
news:x:9:9:news:/var/spool/news:/bin/sh
uucp:x:10:10:uucp:/var/spool/uucp:/bin/sh
proxy:x:13:13:proxy:/bin:/bin/sh
www-data:x:33:33:www-data:/var/www:/bin/sh
backup:x:34:34:backup:/var/backups:/bin/sh
list:x:38:38:Mailing List Manager:/var/list:/bin/sh
irc:x:39:39:ircd:/var/run/ircd:/bin/sh
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
messagebus:x:101:104::/var/run/dbus:/bin/false
colord:x:102:105:colord colour management daemon,,,:/var/lib/colord:/bin/false
saned:x:103:106::/home/saned:/bin/false
tomcat7:x:104:107::/usr/share/tomcat7:/bin/false

我正在尝试解决的是哈德逊(Hadson)中的此错误:

Command "git fetch -t git@________.co.za:_______/_____________.git +refs/heads/*:refs/remotes/origin/*" returned status code 128: Host key verification failed.

这是我的Dockerfile,它需要一个已存在的hudson war文件和配置,并构建映像,hudson运行良好,由于用户tomcat7不存在证书,因此它无法访问git。

FROM debian:wheezy

# install java on image
RUN apt-get update
RUN apt-get install -y openjdk-7-jdk tomcat7

# install hudson on image
RUN rm -rf /var/lib/tomcat7/webapps/*
ADD ./ROOT.tar.gz /var/lib/tomcat7/webapps/

# copy hudson config over to image
RUN mkdir /usr/share/tomcat7/.hudson
ADD ./dothudson.tar.gz /usr/share/tomcat7/
RUN chown -R tomcat7:tomcat7 /usr/share/tomcat7/

# add ssh certificates
RUN mkdir /root/.ssh
ADD ssh.tar.gz /root/

# install some dependencies
RUN apt-get update
RUN apt-get install --y maven
RUN apt-get install --y git
RUN apt-get install --y subversion

# background script
ADD run.sh /root/run.sh
RUN chmod +x /root/run.sh

# expose port 8080
EXPOSE 8080


CMD ["/root/run.sh"]

我正在使用最新版本的Docker(Docker版本1.0.0,内部版本63fe64c / 1.0.0),这是Docker中的错误还是我的Dockerfile中缺少某些内容?


4
您知道USERDockerfile指令吗?
icecrime 2014年

1
不,您建议我使用它做什么?
Jan Vladimir Mostert 2014年

是否可以使用USER指令通过Dockerfile生成证书?
Jan Vladimir Mostert 2014年

3
指令RUN后,您执行的所有USER操作都在相应的uid下完成,因此尽管我不确定我是否完全理解您的问题,但看起来它可能正是您要寻找的。
icecrime 2014年

不幸的是,@ icecrime并非所有内容。COPY以uid 0创建文件,这意味着非root用户不能写RUN chown ...这些文件,并且除非当前用户也是root,否则无法在这些文件上运行。因此,一个人最终在整个Dockerfile中在root用户和另一个用户之间来回切换。
davidA

Answers:


116

您不应sudockerfile中使用,但应使用USERDockerfile中的指令。

Dockerfile构建的每个阶段,都会创建一个新容器,因此您对用户所做的任何更改都不会在下一个构建阶段中持续存在。

例如:

RUN whoami
RUN su test
RUN whoami

这永远不会说用户会test像在第二代whoami上生成新容器一样。输出都将是根目录(除非您事先运行USER)。

但是,如果您这样做:

RUN whoami
USER test
RUN whoami

您应该看到root那么test

或者,您可以使用sudo以其他用户身份运行命令,例如

sudo -u test whoami

但是使用官方支持的指令似乎更好。


我很好奇如何确保以前运行的命令可用于Dockerfile中的用户设置。我有一个问题,在USER按照说明切换到另一个用户后,以前由root设置的文件夹和权限不可用。
斯宾塞·威廉姆斯

3
您可能需要COPY --chown=myuser ...继续前进。
x-yuri

36

作为其他答案的另一种方法,您可以在特定容器上通过命令行按命令执行操作,而不是在Dockerfile上创建映像时指示用户。

使用docker exec,用于--user指定交互式终端将使用哪个用户帐户(容器应该正在运行,并且用户必须存在于容器化系统中):

docker exec -it --user [username] [container] bash

请参阅https://docs.docker.com/engine/reference/commandline/exec/



3

您还应该能够:

apt install sudo

sudo -i -u tomcat

然后,您应该是tomcat用户。目前尚不清楚您使用的是哪个Linux发行版,例如,它可用于Ubuntu 18.04 LTS。


0

如果您需要执行特权任务(例如更改文件夹的权限),则可以以root用户身份执行这些任务,然后创建一个非特权用户并切换到该用户:

From <some-base-image:tag>

# Switch to root user
USER root # <--- Usually you won't be needed it - Depends on base image

# Run privileged command
RUN apt install <packages>
RUN apt <privileged command>

# Set user and group
ARG user=appuser
ARG group=appuser
ARG uid=1000
ARG gid=1000
RUN groupadd -g ${gid} ${group}
RUN useradd -u ${uid} -g ${group} -s /bin/sh -m ${user} <--- the '-m' create a user home directory

# Switch to user
USER ${uid}:${gid}

# Run non-privileged command
RUN apt <non-privileged command>

-8

没有真正的方法可以做到这一点。结果,诸如mysqld_safe之类的事情失败了,并且您不能在没有跳过40个箍的情况下将Debian docker容器中的mysql-server安装在服务器上,因为.....如果不是root用户,它将中止。

您可以使用USER,但如果您不是root用户,则将无法apt-get安装。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.