dockerfile 소개
Docker는 dockerfile의 내용을 읽어 자동으로 이미지를 빌드할 수 있습니다. dockerfile은 빌드 프로세스 중에 실행해야 하는 모든 명령이 포함된 텍스트 파일입니다. 또한 Dockfile은 docker 프로그램에 의해 해석되는 스크립트로, 하나씩 명령어로 구성되어 있으며, 각 명령어는 Linux 시스템의 명령에 해당합니다. docker 프로그램은 이러한 dockerfile 명령어를 실제 Linux 명령으로 변환합니다. Dockerfile에는 고유한 쓰기 형식과 지원되는 명령이 있습니다. docker 프로그램은 makefile과 유사하게 이러한 명령 간의 종속성을 해결합니다.
docker 프로그램은 dockerfile을 읽고 지침에 따라 사용자 정의된 이미지를 생성합니다. 이미지와 같은 블랙박스와 비교할 때 dockerfile과 같은 명확한 스크립트는 사용자가 이미지가 생성되는 방식을 명확하게 보여줍니다. dockerfile을 사용하면 추가 요구 사항을 사용자 정의해야 할 때 dockerfile에 대한 지침을 추가하거나 수정하고 이미지를 재생성하기만 하면 명령을 입력하는 수고가 사라집니다.
Docker 이미지 빌드 방법: commit, dockerfile
1. 커밋을 사용하여 이미지 빌드:
Commit은 원본 이미지를 기반으로 빌드한 이미지입니다. 일부 이미지 구성 정보 및 수정된 정보를 저장합니다. 이미지의 스냅샷과 동일합니다.
2. dockerfile을 사용하여 이미지 빌드:
Dockerfile은 빠르게 빌드하는 데 필요한 (사용자 정의) 이미지입니다.
dockerfile 지침:
from: 기본 이미지를 지정합니다(from은 필수 지침이며 첫 번째 지침이어야 합니다).
run: 명령줄 명령을 실행하는 데 사용됩니다. 기본 형식:
쉘 형식: 실행
Exec 형식: 를 실행합니다. 이 방법은 함수 호출의 형식과 같습니다.
복사: 파일을 복사합니다. 기본 형식:
」 어딘가 | Path>"]
add: 고급 파일 복사, 복사를 기반으로 일부 기능 추가. 압축된 패키지를 복사하면 별도의 작업 없이 직접 압축이 풀립니다. 압축을 풀려면 실행을 사용하세요.
cmd: 컨테이너 시작 명령. 기본 형식:
쉘 형식: cmd
Exec 형식: cmd ["실행 파일", "매개변수 1", "매개변수 2"...]
매개변수 목록 형식: cmd [" 매개변수 1 ", "Parameter 2"...], 진입점 명령을 지정한 후 cmd를 사용하여 특정 매개변수를 지정합니다
Entrypoint: 진입점. 기본 형식은 exec와 shell로 구분됩니다. 진입점의 목적은 컨테이너 시작 프로그램 및 매개변수를 지정하는 cmd와 동일합니다. Entrypoint는 작업 중 교체가 가능하지만 cmd보다 번거롭고 docker run의 --entrypoint 매개변수를 통해 지정해야 합니다. 진입점이 지정되면 cmd의 의미가 변경됩니다. 해당 명령을 직접 실행하는 대신 cmd의 내용이 매개변수로 진입점 명령에 전달됩니다. 실행되면 다음과 같습니다.
env: 환경 변수를 설정합니다. (여기에서 사용된 변수를 사용할 수 있습니다) 기본 형식:
형식 1: env
형식 2: env
arg: 빌드 매개변수. 빌드 매개변수와 env의 효과는 동일합니다. 둘 다 환경 변수를 설정합니다. 차이점은 나중에 컨테이너가 실행될 때 arg로 빌드된 환경 변수가 존재하지 않는다는 것입니다. 기본 형식:
형식 1: arg [=]
형식 2: 이 기본값은 빌드 명령 docker build --build-arg 재정의
볼륨: 익명 볼륨을 정의합니다. 기본 형식:
형식 1: 볼륨 ["
형식 2: 볼륨
노출: 노출된 포트. 노출 지시문은 런타임 컨테이너에서 제공하는 포트를 선언합니다. 컨테이너를 시작할 때 이 선언으로 인해 포트가 열리지 않습니다. 기본 형식:
형식 1:
Workdir: 작업 디렉터리를 지정합니다. 기본 형식:
형식 1: workdir
user: 현재 사용자를 지정합니다. user는 지정된 사용자로 전환하는 데 도움이 됩니다. 기본 형식:
형식 1: 사용자
healthcheck: 컨테이너 상태가 정상인지 확인하는 헬스 체크입니다. 기본 형식: 式 형식 1: Healtcheck [옵션] CMD & LT; Command & GT;: 컨테이너의 상태를 확인하는 명령을 설정합니다. 상태 확인 지침
nginx 이미지 빌드:디렉토리를 만들고 작성합니다. dockerfile 디렉터리에:[root@docker ~]# mkdir mynginx
[root@docker ~]# cd mynginx/
[root@docker mynginx]# pwd
/root/mynginx
[root@docker mynginx]#
nginx 소스 코드 패키지를 생성된 디렉터리(mynginx 디렉터리)에 다운로드:
[root@docker ~]# wget -p /root/mynginx/ http://nginx.org/download/nginx-1.15.2.tar.gz
Write dockerfile:
[root@docker mynginx]# vi dockerfile
내용은 다음과 같습니다.
from centos run ping -c 1 www.baidu.com run yum -y install gcc make pcre-devel zlib-devel tar zlib add nginx-1.15.2.tar.gz /usr/src/ run cd /usr/src/nginx-1.15.2 \ && mkdir /usr/local/nginx \ && ./configure --prefix=/usr/local/nginx && make && make install \ && ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ \ && nginx run rm -rf /usr/src/nginx-1.15.2 expose 80
docker 명령을 실행하여 이미지를 빌드합니다.
[root@docker mynginx]# docker build -t nginx:v3 . sending build context to docker daemon 1.029mb step 1/7 : from centos ---> 5182e96772bf step 2/7 : run ping -c 1 www.baidu.com ---> using cache ---> 2f70f8abaf2a step 3/7 : run yum -y install gcc make pcre-devel zlib-devel tar zlib ---> using cache ---> dbdda4b7ae6f step 4/7 : add nginx-1.15.2.tar.gz /usr/src/ ---> using cache ---> 18ace6285668 step 5/7 : run cd /usr/src/nginx-1.15.2 && mkdir /usr/local/nginx && ./configure --prefix=/usr/local/nginx && make && make install && ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ && nginx ---> using cache ---> 99629488ede9 step 6/7 : run rm -rf /usr/src/nginx-1.15.2 ---> using cache ---> 869fbad71879 step 7/7 : expose 80 ---> using cache ---> 384bed72ea6f successfully built 384bed72ea6f successfully tagged nginx:v3
두 개가 성공적으로 출력되면 빌드가 성공했음을 의미합니다!
사용자 정의 이미지 시작:
도커 이미지를 사용하여 빌드된 이미지 보기:
사용자 정의 이미지 시작:[root@docker ~]# docker run -dit -p 80:80 --name nginx nginx:v3 ecaafe1190447878b98dfb0198e92439db60ff7dab57a1674e0e9e7282a9c858 [root@docker ~]# docker ps -a container id image command created status ports names ecaafe119044 nginx:v3 "/bin/bash" 3 seconds ago up 2 seconds 0.0.0.0:80->80/tcp nginx참고: 현재로서는 컨테이너를 어떻게 시작하든 여전히 컨테이너 상태입니다. 종료된 상태.
다양한 해결 끝에 마침내 문제가 있는 곳을 알아냈습니다. 컨테이너가 시작되면 스레드에 해당하는 백그라운드에서 시작되는 것으로 나타났습니다. 시작 시 이미 시작되었지만 명령을 실행한 후에는 종료되고 백그라운드에서 실행되지 않으므로 -dit 매개변수를 사용하십시오. 그냥 백그라운드에서 실행하세요.
[root@docker ~]# docker run -dit -p 80:80 --name nginx nginx:v3 ecaafe1190447878b98dfb0198e92439db60ff7dab57a1674e0e9e7282a9c858 [root@docker ~]# docker ps -a container id image command created status ports names ecaafe119044 nginx:v3 "/bin/bash" 3 seconds ago up 2 seconds 0.0.0.0:80->80/tcp nginx
그런데...
이때 또 문제가 발생했는데, nginx 웹페이지 인터페이스에 접속이 안되서 접속이 거부되더라구요! ! ! !
[root@docker ~]# curl 192.168.100.22 curl: (7) failed connect to 192.168.100.22:80; 拒绝连接 [root@docker ~]# elinks --dump 192.168.100.22 elinks: 拒绝连接
그러다가 Baidu, fq, Google에 문의한 끝에 마침내 문제를 발견했습니다. 컨테이너에 들어가 nginx를 시작하려면 exec만 사용하면 된다는 것이 밝혀졌습니다.
rrreerrree위 내용은 dockerfile을 사용하여 nginx 이미지를 빌드하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!