Docker 이미지 내부의 사용자를 루트가 아닌 사용자로 전환
SSH 인증서를 설정하기 위해 사용자를 Tomcat7 사용자로 전환하려고 합니다.
내가 할 때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
제가 해결하려고 하는 것은 허드슨의 다음 오류입니다.
Command "git fetch -t git@________.co.za:_______/_____________.git +refs/heads/*:refs/remotes/origin/*" returned status code 128: Host key verification failed.
이것은 나의 도커 파일입니다. 기존의 허드슨 전쟁 파일과 구성이 타르 처리되어 이미지를 구축합니다. 허드슨은 정상적으로 실행되며, 사용자 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의 버그인가요, 아니면 제 Docker 파일에 뭔가 누락된 것인가요?
사용하면 안 됩니다.su
도커 파일에서, 그러나 당신은 사용해야 합니다.USER
명령을 입력합니다.
도커 파일 빌드의 각 단계에서 새 컨테이너가 생성되므로 사용자가 변경한 내용은 다음 빌드 단계에서 유지되지 않습니다.
예:
RUN whoami
RUN su test
RUN whoami
이는 사용자가 다음과 같이 말할 수 없습니다.test
2일 후아미에 새로운 컨테이너가 생성되기 때문입니다.출력은 두 가지 모두에 대해 루트가 됩니다(물론 USER를 사전에 실행하지 않는 한).
하지만 다음 작업을 수행하는 경우:
RUN whoami
USER test
RUN whoami
보셔야 합니다.root
그리고나서test
.
또는 다음과 같은 명령을 sudo와 함께 다른 사용자로 실행할 수 있습니다.
sudo -u test whoami
하지만 공식적인 지원 지침을 사용하는 것이 더 나을 것 같습니다.
도커 파일에서 이미지를 생성할 때 사용자를 표시하는 대신 명령 단위로 특정 컨테이너의 명령줄을 통해 다른 응답 방식을 사용할 수 있습니다.
와 함께docker exec
,사용하다--user
대화형 터미널에서 사용할 사용자 계정을 지정합니다(컨테이너가 실행 중이어야 하며 사용자가 컨테이너화된 시스템에 존재해야 함).
docker exec -it --user [username] [container] bash
https://docs.docker.com/engine/reference/commandline/exec/ 을 참조하십시오.
폴더의 사용 권한 변경과 같은 권한 있는 작업을 수행해야 하는 경우 루트 사용자로 해당 작업을 수행한 다음 권한 없는 사용자를 생성하여 전환할 수 있습니다.
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>
도커 파일에 이 줄 추가
USER <your_user_name>
도커 지침 사용 USER
또한 다음을 수행할 수 있어야 합니다.
apt install sudo
sudo -i -u tomcat
그렇다면 당신이 톰캣 사용자가 되어야 합니다.어떤 Linux 배포판을 사용하고 있는지는 분명하지 않지만 예를 들어 Ubuntu 18.04 LTS에서 작동합니다.
진짜 방법은 없습니다.결과적으로 mysqld_safe와 같은 것들이 실패하고, 40개의 후프를 건너뛰지 않고서는 데비안 도커 컨테이너에 mysql-server를 설치할 수 없습니다.음...루트가 아니면 중단됩니다.
USER를 사용할 수 있지만 루트가 아니면 apt-get 설치를 할 수 없습니다.
언급URL : https://stackoverflow.com/questions/24549746/switching-users-inside-docker-image-to-a-non-root-user
'programing' 카테고리의 다른 글
소스 제어의 .vs\config\applicationhost.config (0) | 2023.05.06 |
---|---|
터미널을 사용하여 Mac OS X에서 C 프로그램을 실행하려면 어떻게 해야 합니까? (0) | 2023.05.06 |
MSSQL GetDate()를 사용할 때 어떻게 날짜만 알 수 있습니까? (0) | 2023.05.06 |
이미지를 로드할 때 WPF에서 "리소스를 찾을 수 없음" 예외가 발생함 (0) | 2023.05.06 |
"git clone 중에 'https'에 대한 원격 도우미를 찾을 수 없습니다. (0) | 2023.05.06 |