我试图将用户切换到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
我试图解决的是Hudson中的这个错误:
Command "git fetch -t git@________.co.za:_______/_____________.git +refs/heads/*:refs/remotes/origin/*" returned status code 128: Host key verification failed.
这是我的Dockerfile,它需要一个现有的hudson war文件和tar tar并构建一个映像,hudson运行正常,它只是无法访问git,因为用户tomcat7不存在证书。
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中遗漏了什么?
答案 0 :(得分:74)
您不应在dockerfile中使用su
,但是您应该使用Dockerfile中的USER
指令。
在Dockerfile版本的每个阶段,都会创建一个新容器,因此您对用户所做的任何更改都不会在下一个构建阶段保留。
例如:
RUN whoami
RUN su test
RUN whoami
这绝不会说用户会test
,因为新的容器会在第二个whoami上产生。输出在两者上都是root(除非你事先运行USER)。
如果你这样做:
RUN whoami
USER test
RUN whoami
您应该看到root
然后test
。
或者,您可以使用带有类似
的sudo作为其他用户运行命令sudo -u test whoami
但使用官方支持的指令似乎更好。
答案 1 :(得分:19)
作为另一个答案的另一种方法,不是在Dockerfile上创建映像时指示用户,而是可以通过命令行在特定容器上执行此操作,作为每个命令。
使用docker exec
,使用--user
指定交互式终端将使用的用户帐户(容器应该运行且用户必须存在于容器化系统中):
docker exec -it --user [username] [container] bash
请参阅https://docs.docker.com/engine/reference/commandline/exec/
答案 2 :(得分:1)
答案 3 :(得分:1)
如果您需要执行特权任务(例如更改文件夹的权限),则可以以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>
答案 4 :(得分:0)
您还应该能够:
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui">
.....
<p:dialog header="#{messages['listado.crear.CABECERA']} - #{messages['entidades.PLATAFORMA']}"
widgetVar="dialogoCrearPlataformaWV" id="dialogoCrearPlataforma"
modal="true" resizable="false" closable="false">
<h:form enctype="multipart/form-data">
<p:panelGrid columns="2" style="width: 100%">
<h:outputText value="#{messages['listado.NOMBRE']}" />
<h:inputText value="#{listadoPlataformas.plataformaCrear.nombre}"
style="width: 100%" />
<h:outputText value="#{messages['listado.LOGO']}" />
<p:panelGrid columns="2" style="width: 100%">
<p:fileUpload label="#{messages['comun.SELECCIONAR']}" id="crearFileUpload"
widgetVar="crearFileUploadWV" multiple="false" fileLimit="1"
fileUploadListener="#{listadoPlataformas.subidaAutomaticaImagenCrear}" />
</p:panelGrid>
</p:panelGrid>
<p:panelGrid columns="2" style="width:100%; text-align:center;">
<p:commandButton value="#{messages['comun.ACEPTAR']}"
id="crearPlataformaAceptar" ajax="true" onclick="PF('crearFileUploadWV').upload();"
actionListener="#{listadoPlataformas.crearPlataforma}"
update="formularioPrincipal:listadoPlataformas formularioPrincipal:growl" />
<p:commandButton value="#{messages['comun.CANCELAR']}"
onclick="PF('dialogoCrearPlataformaWV').hide();" />
</p:panelGrid>
</h:form>
</p:dialog>
</html>
apt install sudo
然后您应该是tomcat用户。目前尚不清楚您使用的是哪个Linux发行版,例如,它可用于Ubuntu 18.04 LTS。
答案 5 :(得分:-7)
没有真正的方法可以做到这一点。结果,像mysqld_safe这样的东西失败了,你不能在Debian docker容器中安装mysql-server而不跳过40个篮球因为......好吧......如果它不是root就会中止。
您可以使用USER,但如果您不是root用户,则无法进行apt-get安装。