>운영 및 유지보수 >Docker >도커 컨테이너를 가르치는 내용

도커 컨테이너를 가르치는 내용

王林
王林원래의
2023-05-13 12:24:37718검색

Docker 컨테이너 튜토리얼: 초보자부터 숙련까지

Docker는 애플리케이션과 해당 종속성을 컨테이너로 패키징할 수 있는 오픈 소스 컨테이너화 플랫폼으로, 어디서나 실행할 수 있도록 일관된 개발 및 실행 환경을 제공합니다. Docker의 컨테이너화 기술은 DevOps 및 클라우드 컴퓨팅 분야에서 널리 사용되어 왔으며 오늘날 가장 인기 있는 컨테이너화 도구 중 하나이기도 합니다.

이 튜토리얼에서는 Docker 컨테이너의 기본부터 시작하여 Docker 컨테이너의 주요 측면에 익숙해질 때까지 점차 심화해 나가겠습니다.

1. Docker 컨테이너에 대한 기본 지식

  1. Docker 컨테이너 시작하기

Docker에는 이미지와 컨테이너라는 두 가지 핵심 개념이 있습니다. 이미지는 애플리케이션과 해당 종속성을 포함하는 가벼운 읽기 전용 템플릿입니다. 컨테이너는 이미지를 기반으로 생성된 실행 인스턴스로, 일반적으로 애플리케이션이나 테스트 환경을 실행하는 데 사용됩니다.

다음 명령을 통해 Docker에서 컨테이너를 실행합니다.

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

그 중 OPTIONS는 컨테이너의 옵션을 나타내고, IMAGE는 컨테이너가 기반으로 하는 이미지를 나타내며, COMMAND와 ARG는 컨테이너가 실행할 명령과 해당 컨테이너를 나타냅니다. 매개변수.

예를 들어 다음 명령은 Docker에서 Ubuntu 이미지 기반 컨테이너를 실행하고 /bin/bash 명령을 실행합니다.

docker run -it ubuntu /bin/bash
  1. Docker 컨테이너 상태 보기

Docker 컨테이너의 상태를 보려면 다음을 사용하세요. 명령:

docker ps [OPTIONS]

OPTIONS는 컨테이너 목록의 옵션을 나타냅니다.

  • -a: 중지된 컨테이너를 포함하여 모든 컨테이너를 표시합니다.
  • -q: 컨테이너 ID만 표시합니다.
  • -l: 최신 컨테이너를 표시합니다.
  • -n: 최근 생성된 n개의 컨테이너를 표시합니다.

예를 들어 다음 명령은 실행 중인 Docker 컨테이너를 나열합니다.

docker ps
  1. Docker 컨테이너에 패키지 설치

Dockerfile 파일을 사용하여 Docker 컨테이너 환경에 설치해야 하는 패키지를 정의할 수 있습니다. Dockerfile은 Docker 이미지를 빌드하는 데 사용되는 여러 명령과 매개변수가 포함된 텍스트 파일입니다. Dockerfile의 예시 내용은 다음과 같습니다.

FROM ubuntu:latest
RUN apt-get update && apt-get install -y nginx

위 Dockerfile은 Ubuntu Linux 배포판을 기반으로 이미지를 정의하고 apt-get 명령을 사용하여 nginx 패키지를 설치합니다. 그런 다음 다음 명령을 사용하여 이미지를 빌드할 수 있습니다.

docker build -t my-nginx-image .

여기서 my-nginx-image는 이미지의 이름이고 "."은 Dockerfile이 있는 디렉터리의 현재 디렉터리를 나타냅니다.

2. Docker 컨테이너의 고급 애플리케이션

  1. Docker 컨테이너 확장

Docker 컨테이너는 더 높은 부하에 맞게 확장될 수 있습니다. 다음 명령을 사용하여 여러 컨테이너를 만들 수 있습니다.

docker-compose up -d

여기서 -d 옵션은 컨테이너를 백그라운드 프로세스로 실행한다는 의미입니다.

  1. Docker 컨테이너 입력

때로는 Docker 컨테이너에서 파일 확인, 명령 실행 등 일부 작업을 수행해야 하는 경우가 있습니다. 다음 명령을 사용하여 실행 중인 Docker 컨테이너에 들어갈 수 있습니다.

docker exec -it [CONTAINER ID] /bin/bash

여기서 CONTAINER ID는 컨테이너의 ID를 나타냅니다. 예:

docker exec -it bb0cd62f8cac /bin/bash
  1. Developing with Docker Containers

Docker 컨테이너를 사용하여 개발하여 개발 환경에서 일관성과 안정성을 달성할 수 있습니다. 다음 명령을 사용하여 컨테이너를 시작하고 현재 디렉터리를 볼륨으로 컨테이너에 마운트할 수 있습니다.

docker run --rm -it -v $(pwd):/app node:latest /bin/bash

그중 -rm 옵션은 컨테이너 실행이 완료된 후 컨테이너가 자동으로 삭제된다는 의미입니다. -v 옵션은 호스트의 현재 디렉터리($(pwd))를 Docker 컨테이너의 /app 디렉터리에 마운트하는 것을 의미합니다. node:latest는 Docker 이미지이며 /bin/bash 명령을 실행합니다.

  1. Docker 컨테이너의 보안

Docker 컨테이너는 더 나은 운영 보안을 제공하는 동시에 악의적인 공격으로부터 애플리케이션과 시스템을 보호합니다. Docker 컨테이너를 보호하기 위한 몇 가지 제안 사항은 다음과 같습니다.

  • 최신 Docker 이미지를 사용해야 합니다.
  • 컨테이너는 최소한의 사용자 권한으로 실행되어야 합니다.
  • 컨테이너는 복잡한 비밀번호로 보호해야 합니다.
  • 취약성 공격을 방지하려면 컨테이너와 이미지를 정기적으로 업데이트해야 합니다.

3. Docker 컨테이너의 고급 애플리케이션

  1. 컨테이너 오케스트레이션을 위해 Docker Compose 사용

Docker Compose는 여러 컨테이너를 관리하는 데 사용되는 Docker의 오케스트레이션 도구입니다. Docker Compose 파일은 다음 명령을 사용하여 정의할 수 있습니다.

version: '3'
services:
  web:
    build: .
    ports:
      - "5000:5000"
  redis:
    image: "redis:alpine"

여기서 버전 3은 Docker Compose 파일 형식의 버전입니다. 서비스는 웹 및 Redis를 포함하여 관리해야 하는 서비스를 정의합니다. 그 중 web은 빌드 정의를 사용하여 현재 디렉터리를 빌드 컨텍스트로 사용하고, redis는 이미지를 사용하여 Docker Hub에서 Redis 이미지를 가져옵니다.

  1. Kubernetes에서 Docker 컨테이너 실행

Kubernetes는 Docker 컨테이너를 자동으로 관리하는 널리 사용되는 컨테이너 오케스트레이션 시스템입니다. 다음은 Kubernetes를 사용한 컨테이너 오케스트레이션의 예입니다.

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: my-app
  template:
    metadata:
      labels:
        app: my-app
    spec:
      containers:
        - name: my-container
          image: my-image:latest
          ports:
            - containerPort: 8080

이 Kubernetes 매니페스트 파일은 "my-deployment"라는 배포를 정의하고 3개의 복제본을 실행합니다. 또한 "my-container"라는 컨테이너를 정의하고 my-image:latest 이미지를 사용하며 포트 8080에 서비스를 노출합니다.

결론

Docker 컨테이너 기술은 DevOps 및 클라우드 컴퓨팅 분야에 강력한 도구를 제공하여 개발 및 운영 중에 일관성과 안정성을 제공합니다. 이 튜토리얼에서는 Docker 컨테이너의 기본 사항, 고급 애플리케이션 및 고급 애플리케이션을 심층적으로 살펴보고 실용적인 예를 제공하여 이 중요한 기술을 이해하고 사용하는 데 도움을 드리고자 합니다.

위 내용은 도커 컨테이너를 가르치는 내용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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