운영 및 유지보수 Docker Docker 컨테이너에 사용자를 추가할 수 없습니다.

Docker 컨테이너에 사용자를 추가할 수 없습니다.

May 13, 2023 pm 04:47 PM

최근 클라우드 컴퓨팅과 컨테이너화 기술의 급속한 발전으로 Docker는 가장 인기 있는 컨테이너 기술 중 하나가 되었습니다. 그러나 Docker가 널리 사용되고 있음에도 불구하고 Docker 컨테이너를 사용할 때 해결해야 할 몇 가지 일반적인 문제가 여전히 남아 있습니다. 문제 중 하나는 Docker 컨테이너 내에 사용자를 추가할 수 없다는 것입니다.

Docker 컨테이너에 사용자를 추가할 수 없는 이유는 무엇인가요?

먼저 Docker가 내부적으로 어떻게 작동하는지 이해해야 합니다. Docker는 Linux 커널 네임스페이스를 사용하여 프로세스 간 격리를 달성합니다. 이러한 네임스페이스에는 PID 네임스페이스, UTS 네임스페이스, 네트워크 네임스페이스 등이 포함됩니다. 그 중 사용자 네임스페이스는 사용자와 사용자 그룹 ID를 분리하는 데 사용됩니다. 기본적으로 Docker 컨테이너는 호스트 사용자 네임스페이스의 UID 및 GID를 사용합니다. 즉, 새 사용자가 생성되면 컨테이너의 네임스페이스에 해당 UID 및 GID가 없기 때문에 컨테이너에서 useradd와 같은 명령을 사용하여 사용자를 생성할 수 없습니다. useradd等命令创建用户,因为再创建一个新用户时,容器内的命名空间中没有对应的UID和GID。

如何在Docker容器内增加用户?

要在Docker容器内增加用户,我们需要进行一些额外的操作。具体来说,我们需要通过修改容器的配置文件来启用用户namespace,并为该用户命名空间指定一个独立的UID和GID,并将容器内的root用户映射到该命名空间的用户。

以Ubuntu为例,在容器内使用以下命令即可启用用户namespace:

sysctl kernel.unprivileged_userns_clone=1
로그인 후 복사

该命令将允许非特权用户对用户命名空间进行克隆(clone)操作。接下来,我们需要为该用户命名空间指定一个独立的UID和GID,并将容器内的root用户映射到该命名空间的用户,使用以下命令:

echo "namespace    id  range" > /etc/subuid
echo "namespace    id  range" > /etc/subgid
로그인 후 복사

其中,namespace为该用户命名空间的命名空间ID,id为该用户命名空间的初始UID和GID,range为该用户命名空间允许的用户数目。

接下来,我们需要使用adduser

Docker 컨테이너에 사용자를 추가하는 방법은 무엇입니까?

Docker 컨테이너 내에 사용자를 추가하려면 몇 가지 추가 작업을 수행해야 합니다. 특히, 컨테이너의 구성 파일을 수정하여 사용자 네임스페이스를 활성화하고, 사용자 네임스페이스에 대해 독립적인 UID 및 GID를 지정하고, 컨테이너의 루트 사용자를 네임스페이스 사용자에 매핑해야 합니다.

Ubuntu를 예로 들어 컨테이너에서 다음 명령을 사용하여 사용자 네임스페이스를 활성화합니다.

adduser --uid 1000 --gid 1000 myuser
로그인 후 복사
이 명령을 사용하면 권한 없는 사용자가 사용자 네임스페이스를 복제할 수 있습니다. 다음으로, 사용자 네임스페이스에 대해 독립적인 UID 및 GID를 지정하고 컨테이너의 루트 사용자를 네임스페이스 사용자에 매핑해야 합니다. 🎜rrreee🎜 여기서 네임스페이스는 사용자 네임스페이스 공간 ID의 이름입니다. , id는 사용자 네임스페이스의 초기 UID와 GID이고, range는 사용자 네임스페이스에 허용되는 사용자 수입니다. 🎜🎜다음으로 adduser 명령을 사용하여 새 사용자를 생성하고 해당 사용자를 컨테이너에 추가해야 합니다. 🎜rrreee🎜 그중 --uid 및 --gid 매개변수는 사용자를 컨테이너에 추가합니다. 이전에 정의한 별도의 UID 및 GID 네임스페이스에 있습니다. 🎜🎜요약🎜🎜Docker 컨테이너에 사용자를 추가할 수 없는 문제는 사용자 네임스페이스를 활성화하고 네임스페이스에 대해 독립적인 UID 및 GID를 지정하면 해결할 수 있습니다. 이를 위해서는 약간의 추가 작업이 필요하지만 안전성과 격리성이 향상되면 그만한 가치가 있습니다. 컨테이너 기술이 계속해서 발전함에 따라 미래에는 더 간단하고 편리한 솔루션이 등장할 것이라고 믿습니다. 🎜

위 내용은 Docker 컨테이너에 사용자를 추가할 수 없습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker 인터뷰 질문 : Ace Your DevOps 엔지니어링 인터뷰 Docker 인터뷰 질문 : Ace Your DevOps 엔지니어링 인터뷰 Apr 06, 2025 am 12:01 AM

Docker는 DevOps 엔지니어에게 필수 기술입니다. 1. Docker는 포장 애플리케이션 및 컨테이너에 대한 종속성을 통해 격리 및 휴대 성을 달성하는 오픈 소스 컨테이너화 플랫폼입니다. 2. Docker는 네임 스페이스, 제어 그룹 및 연합 파일 시스템과 함께 작동합니다. 3. 기본 사용에는 컨테이너 생성, 실행 및 관리가 포함됩니다. 4. 고급 사용법에는 DockerCompose를 사용하여 다중 컨테이너 응용 프로그램을 관리하는 것이 포함됩니다. 5. 일반적인 오류에는 컨테이너 고장, 포트 매핑 문제 및 데이터 지속성 문제가 포함됩니다. 디버깅 기술에는 로그보기, 컨테이너 입력 및 자세한 정보보기가 포함됩니다. 6. 성능 최적화 및 모범 사례에는 이미지 최적화, 리소스 제약 조건, 네트워크 최적화 및 Dockerfile 사용을위한 모범 사례가 포함됩니다.

Docker Volumes : 컨테이너의 지속적인 데이터 관리 Docker Volumes : 컨테이너의 지속적인 데이터 관리 Apr 04, 2025 am 12:19 AM

DockErvolumes는 컨테이너가 다시 시작, 삭제 또는 마이그레이션 될 때 데이터가 안전하게 유지되도록합니다. 1. 볼륨 생성 : dockervolumecreatemydata. 2. 컨테이너를 실행하고 볼륨을 장착하십시오 : Dockerrun-it-vmydata :/app/dateubuntubash. 3. 고급 사용에는 데이터 공유 및 백업이 포함됩니다.

Docker의 이미지를 업데이트하는 방법 Docker의 이미지를 업데이트하는 방법 Apr 15, 2025 pm 12:03 PM

Docker 이미지를 업데이트하는 단계는 다음과 같습니다. 최신 이미지 태그 가져 오기 새 이미지 특정 태그의 이전 이미지 삭제 (선택 사항) 컨테이너를 다시 시작하십시오 (필요한 경우)

Docker Security Hardening : 컨테이너를 취약성으로부터 보호합니다 Docker Security Hardening : 컨테이너를 취약성으로부터 보호합니다 Apr 05, 2025 am 12:08 AM

Docker Security 향상 방법에는 다음이 포함됩니다. 1.-캡 드롭 매개 변수를 사용하여 Linux 기능을 제한, 2. 읽기 전용 컨테이너 생성, 3. Selinux 태그 설정. 이러한 전략은 취약성 노출을 줄이고 공격자 기능을 제한함으로써 컨테이너를 보호합니다.

Docker가 컨테이너를 빠져 나가는 방법 Docker가 컨테이너를 빠져 나가는 방법 Apr 15, 2025 pm 12:15 PM

도커 컨테이너를 종료하는 4 가지 명령 사용 Docker Kill & lt; Container_name & gt; 호스트 터미널의 명령 (힘 출구)

Docker의 파일을 외부로 복사하는 방법 Docker의 파일을 외부로 복사하는 방법 Apr 15, 2025 pm 12:12 PM

Docker의 외부 호스트에 파일을 복사하는 방법 : Docker CP 명령 사용 : Docker CP 실행 [옵션] & lt; 컨테이너 경로 & gt; & lt; 호스트 경로 & gt;. 데이터 볼륨 사용 : 호스트에서 디렉토리를 만들고 -V 매개 변수를 사용하여 양방향 파일 동기화를 달성하기 위해 컨테이너를 만들 때 컨테이너에 디렉토리를 장착하십시오.

Docker를 다시 시작하는 방법 Docker를 다시 시작하는 방법 Apr 15, 2025 pm 12:06 PM

Docker 컨테이너를 다시 시작하는 방법 : 컨테이너 ID (Docker PS)를 가져옵니다. 컨테이너 중지 (Docker Stop & lt; container_id & gt;); 컨테이너를 시작하십시오 (Docker start & lt; container_id & gt;); 재시작이 성공했는지 확인하십시오 (Docker PS). 기타 방법 : Docker Compose (Docker-Compose Restart) 또는 Docker API (Docker 문서 참조).

Docker Desktop을 사용하는 방법 Docker Desktop을 사용하는 방법 Apr 15, 2025 am 11:45 AM

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).

See all articles