GUI없는 머신에서 최초로 일반 유저 log in을 할 때 source가 되는 스크립트들은 어떤 것인가요?
executable한 docker container를 만들고 있습니다. 커맨드를 따로 주지 않으면 /bin/bash가 수행되고, 따로 주면 그 커맨드가 대신 수행되어야 합니다. 아래와 같이 쓰게끔 되어 있습니다.
docker run mydocker docker run mydocker gcc --version
그래서 Dockerfile의 마지막은 이렇게 되어 있습니다.
ENTRYPOINT ["entry.sh"] CMD ["/bin/bash"]
문제는 각 명령어를 실행하는 user인데, 이 user가 docker container를 돌리는 host machine의 user와 같아야 합니다. 예컨대 저희 팀원이 넷이라고 치면, 그 넷이 아래와 같이 docker run을 실행하면, 각자의 uid, gid, user account로 해당 명령어가 실행되어야 합니다.
docker run \ --privileged \ -v $HOME/workspace:$HOME/workspace \ -e LOCAL_USER_ID=`id -u $USER` \ -e LOCAL_USER_NAME="$USER" \ -it $IMAGE_NAME:$IMAGE_TAG "$@"
현재 LOCAL_USER_ID 등등을 받아 docker container 내에 사용자를 추가하고 홈 디렉토리를 만드는 등등은 해결이 되었습니다.
문제는 이 "$@"를 실행할 때, 그 host user와 같은 docker container user로 실행을 하는 부분입니다. 아래가 제가 처음 작성한 entry.sh의 마지막 라인입니다.
(cd /home/$USER_NAME; exec gosu "$USER_NAME" "$@"; exit)
이 경우 문제가 있었습니다. 구체적으로 USER 환경변수가 셋팅이 되어 있지 않아서 docker container 내에서 빌드가 되는 프로그램이 정상적으로 빌드되지 않더군요. 이유는 exec gosu를 하면서 /etc/profile이 source가 되지 않아서였습니다. 그래서 entry.sh을 다음과 같이 변경하려고 생각하게 됐습니다.
(cd /home/$USER_NAME; exec gosu "$USER_NAME" /usr/local/bin/execute.sh "$@"; exit)
execute.sh은 아래와 같습니다.
#!/bin/bash # source the required scripts such as .bashrc? exec "$@"
이제 의문은 과연 어떤 스크립트를 어떤 순서로 source를 해줘야 하는가인 것 같습니다. source .bashrc만으로는 여전히 /etc/profile이 source가 되지 않는 것 같더군요. 어떤 스크립트를 어떤 순서로 source를 해줘야 할까요?
감사합니다.
자문자답
https://askubuntu.com/questions/463462/sequence-of-scripts-sourced-upon-login
여기에 찾던 정보가 있네요.
다 개무시하고 원하는 환경변수만 설정한다.
다 개무시하고 원하는 환경변수만 설정한다.
`env -i`
그럴 수도 있다, 하는 댓글입니다.
감사합니다
다만 제 상황에서 필요한 건, 첫째, docker run -e 로 설정한 환경변수와 Dockerfile에서 설정된 환경변수는 넘어가줘야 하고, 둘째, docker run을 하는 host user가 container의 OS와 같은 걸 쓴다는 가정 하에 최대한 docker container를 갓 설치된 host OS처럼 경험하게 해주는 것입니다. 또 host OS의 설정 파일이 이따금 업데이트 되는데 이 업데이트를 docker container도 자동적으로 따라가게 해주면 좋구요. 그래서 env -i는 제 상황에는 안 맞는 것 같습니다.
댓글 달기