chroot는 docker에서 무엇을 합니까?
docker에서 chroot는 Unix 및 Linux 시스템의 작업으로, 실행 중인 소프트웨어 프로세스와 해당 하위 프로세스의 루트 디렉터리를 변경하여 프로그램이 디렉터리에 액세스할 수 없도록 합니다. 디렉토리 이외의 것.
이 튜토리얼의 운영 환경: linux7.3 시스템, docker-1.13.1 버전, Dell G3 컴퓨터.
docker에서 chroot의 기능은 무엇인가요?
chroot
컨테이너 기술은 1979년 chroot가 처음 등장한 이후 등장했습니다.
Wikipedia는 chroot를 다음과 같이 정의합니다.
는 Unix 및 Linux 시스템에서 실행 중인 소프트웨어 프로세스와 해당 하위 프로세스의 명백한 루트 디렉터리를 변경하는 작업입니다. 이 환경에서 실행되고 chroot를 통해 루트 디렉터리를 설정하는 프로그램은 지정된 루트 디렉터리 외부의 파일에 액세스할 수 없고 읽을 수 없으며 해당 내용을 변경할 수 없습니다.
일반인의 관점에서 보면 chroot는 프로그램이 디렉토리 외부의 다른 디렉토리에 액세스할 수 없도록 프로세스의 루트 디렉토리를 변경할 수 있습니다. 이는 컨테이너에서 수행하는 작업과 매우 유사합니다. 아래에서는 chroot를 시연하기 위해 예제를 사용합니다. ㅋㅋㅋ (docker create docker101tutorial) -o docker101tutorial.tar
#docker101tutorial이라는 컨테이너의 파일 시스템을 docker101tutorial.tar 아카이브 파일로 docker101tutorial.tar에 내보내고 저장합니다
#Created some과 같이 간단히 이해할 수도 있습니다. 디렉토리에 일부 바이너리 파일을 배치하고 rootfs
4), tar -xf docker101tutorial.tar
#docker101tutorial.tar 파일의 내용 추출
5), ls
#현재 rootfs 디렉토리의 파일 내용 보기
6), chroot /Users/xiaoqin.wu/rootfs /bin/sh
#sh 프로세스를 시작하고 /Users/xiaoqin.wu/rootfs를 sh 프로세스의 루트 디렉터리로 사용합니다
비교 위 그림에서 /Users/xiaoqin.wu/rootfs 디렉터리의 파일 내용을 보기 위한 5번 명령: ls의 결과는 sh 프로세스에서 현재 프로세스를 보기 위해 7번 명령: ls를 사용한 결과와 일치합니다. 이 시점에서 chroot를 사용하면 현재 프로세스가 실현되고 호스트 격리와 디렉터리 격리 컨테이너가 완료되었지만 아직 컨테이너라고 부를 수는 없음을 보여줍니다.
이유는 다음과 같습니다.
라우팅 정보를 보려면 8번 명령어: netstat -nr을 사용하세요
결과를 보면 네트워크 정보가 분리되어 있지 않은 것으로 나타났습니다. 실제로는 프로세스와 기타 정보가 분리되어 있습니다. 완전한 컨테이너를 구현하려면 세 가지 다른 Linux 기술, 즉
docker 비디오 튜토리얼"
위 내용은 chroot는 docker에서 무엇을 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

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

Docker Container Startup 단계 : 컨테이너 이미지를 당기기 : "Docker Pull [Mirror Name]"을 실행하십시오. 컨테이너 생성 : "docker"[옵션] [미러 이름] [명령 및 매개 변수]를 사용하십시오. 컨테이너를 시작하십시오 : "Docker start [컨테이너 이름 또는 ID]"를 실행하십시오. 컨테이너 상태 확인 : 컨테이너가 "Docker PS"로 실행 중인지 확인하십시오.

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

단계를 따르면 Docker 컨테이너 이름을 쿼리 할 수 있습니다. 모든 컨테이너 (Docker PS)를 나열하십시오. 컨테이너 목록을 필터링합니다 (GREP 명령 사용). 컨테이너 이름 ( "이름"열에 위치)을 가져옵니다.

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에서 MySQL을 시작하는 프로세스는 다음 단계로 구성됩니다. MySQL 이미지를 가져와 컨테이너를 작성하고 시작하고 루트 사용자 암호를 설정하고 포트 확인 연결을 매핑하고 데이터베이스를 작성하고 사용자는 데이터베이스에 모든 권한을 부여합니다.

Docker에서 컨테이너 만들기 : 1. 이미지를 당기기 : Docker Pull [Mirror Name] 2. 컨테이너 만들기 : Docker Run [옵션] [미러 이름] [명령] 3. 컨테이너 시작 : Docker Start [컨테이너 이름]

Docker Logs를 보는 방법에는 다음이 포함됩니다. Docker Logs 명령 사용 : Docker Logs Container_name Docker Exec 명령을 사용하여 RUN /BIN /SH를 사용하여 로그 파일을 봅니다. cat /var/log/container_name.log docker-compose logs docker compose의 명령 : docker-compose -f docker-com 사용
