> 운영 및 유지보수 > 리눅스 운영 및 유지 관리 > 컨테이너의 자동화된 배포 및 롤백을 위해 Docker를 사용하는 방법

컨테이너의 자동화된 배포 및 롤백을 위해 Docker를 사용하는 방법

WBOY
풀어 주다: 2023-11-07 13:40:59
원래의
1164명이 탐색했습니다.

컨테이너의 자동화된 배포 및 롤백을 위해 Docker를 사용하는 방법

클라우드 컴퓨팅과 마이크로서비스의 인기와 함께 경량 가상화 기술인 Docker는 컨테이너 배포에 널리 사용됩니다. Docker는 신속한 배포, 리소스 격리, 손쉬운 관리 등의 장점을 갖고 있어 애플리케이션 유지 관리 및 릴리스 프로세스를 크게 단순화할 수 있습니다. 이 문서에서는 컨테이너의 자동화된 배포 및 롤백을 위해 Docker를 사용하는 방법을 소개하고 몇 가지 구체적인 코드 예제를 제공합니다.

1. Docker 자동 배포

Docker 자동 배포는 애플리케이션 개발 및 테스트 프로세스 중에 Dockerfile 파일 및 Docker Compose 파일을 작성하여 애플리케이션 환경 및 관련 종속성이 Docker 이미지로 패키징되고 로컬 또는 로컬에 자동으로 배포되는 것을 의미합니다. 원격 서버.

1. Dockerfile 작성

Dockerfile은 애플리케이션이 이미지를 빌드하는 데 필요한 모든 지침과 명령을 포함하는 텍스트 파일입니다. Dockerfile을 작성하여 애플리케이션에 필요한 환경, 종속성 및 시작 명령을 정의할 수 있습니다. 애플리케이션에 필요한 Docker 이미지를 자동으로 빌드하려면 단일 명령만 실행하면 됩니다.

다음은 Dockerfile을 사용하여 Node.js 애플리케이션을 빌드하는 예입니다.

FROM node:14-alpine
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 3000
CMD ["npm", "start"]
로그인 후 복사

위 Dockerfile에서는 기본 이미지를 Node.js 14 버전의 alpine 기본 이미지로 지정하고 작업 디렉터리를 /app으로 정의하며, packages.json 및 package-lock.json을 작업 디렉터리에 복사하고, npm install을 실행하여 종속성을 설치하고, 애플리케이션 코드를 작업 디렉터리에 복사하고, 컨테이너가 매핑할 포트를 3000으로 정의하고, 마지막으로 npm start를 실행하여 응용 프로그램을 시작합니다.

2. Docker Compose 파일 작성

Docker Compose는 여러 컨테이너로 구성된 애플리케이션을 정의하고 실행하기 위해 Docker에서 공식적으로 제공하는 도구입니다. Docker Compose 파일을 작성하면 애플리케이션에 필요한 서비스, 컨테이너의 이미지 및 시작 방법, 컨테이너 간의 네트워크 및 종속성, 기타 정보, 컨테이너의 리소스 제한 및 확장을 정의할 수 있습니다.

다음은 Docker Compose를 사용하여 Node.js 애플리케이션을 배포하는 예입니다.

version: '3'

services:
  app:
    build: .
    ports:
      - '8080:3000'
    environment:
      NODE_ENV: production
    restart: always
로그인 후 복사

위 Docker Compose 파일에 app이라는 서비스가 정의되어 있습니다. build 명령을 사용하여 이미지를 빌드하고 컨테이너 포트를 호스트 포트 8080, 정의 환경 변수 NODE_ENV는 프로덕션이며 지정된 컨테이너는 충돌 후 자동으로 다시 시작됩니다.

3. 자동화된 배포 스크립트

애플리케이션 배포 프로세스를 더욱 자동화하기 위해 일부 배포 스크립트를 작성하여 Docker 이미지를 자동으로 빌드, 푸시 및 배포하는 전체 프로세스를 실현할 수 있습니다. 다음은 Docker Compose를 사용하여 Node.js 애플리케이션을 자동으로 배포하는 예입니다.

#!/bin/bash

# 定义应用名称和版本号
APP_NAME='nodejs-app'
TAG=$(git rev-parse --short HEAD)

# 构建Docker镜像
docker build -t $APP_NAME:$TAG .

# 推送Docker镜像到仓库
docker push $APP_NAME:$TAG

# 使用Docker Compose部署应用
docker-compose up -d
로그인 후 복사

위 스크립트에서 git rev-parse 명령을 사용하여 최신 코드의 버전 번호를 얻고 이미지를 빌드한 후 푸시합니다. Docker Warehouse를 선택하고 마지막으로 Docker Compose를 사용하여 애플리케이션을 시작합니다( -d 매개변수는 백그라운드에서 실행 중임을 나타냄).

2. Docker 컨테이너 롤백

애플리케이션 개발 및 테스트 프로세스 중에 일부 코드 오류나 비호환성 문제가 필연적으로 발생합니다. 이때 애플리케이션 버전을 롤백하고 애플리케이션을 이전 상태로 복원해야 합니다.

Docker 컨테이너는 태그를 통해 버전 번호를 지정하는 간단한 롤백 방법을 제공합니다. 컨테이너가 시작될 때 다양한 이미지 버전을 선택하여 애플리케이션 버전 롤백을 구현할 수 있습니다.

1. 태그 사용

Dockerfile 파일에 버전 번호를 지정할 때 태그를 사용하여 애플리케이션 버전을 식별할 수 있습니다. 예:

FROM node:14-alpine

LABEL version="1.0.0"

WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 3000
CMD ["npm", "start"]
로그인 후 복사

LABEL 명령어는 위 Dockerfile에서 애플리케이션 버전 번호를 1.0.0으로 식별하는 데 사용됩니다.

이미지를 빌드한 후 docker tag 명령을 사용하여 새 태그를 생성할 수 있습니다. 예:

docker tag nodejs-app:latest nodejs-app:1.0.0
로그인 후 복사

Docker Compose 파일에서 서비스를 정의할 때 사용할 태그를 지정할 수 있습니다. 예:

version: '3'

services:
  app:
    image: nodejs-app:1.0.0
    ports:
      - '8080:3000'
    environment:
      NODE_ENV: production
    restart: always
로그인 후 복사

2. 롤백 스크립트 반환

버전 롤백을 용이하게 하기 위해 사용해야 하는 이미지 버전을 지정하여 애플리케이션 버전의 롤백을 구현하는 롤백 스크립트를 작성할 수 있습니다. 다음은 Docker Compose를 사용하여 Node.js 애플리케이션을 롤백하는 예입니다.

#!/bin/bash

# 定义应用名称和版本号
APP_NAME='nodejs-app'
TAG='1.0.0'

# 更新Docker Compose文件中使用的镜像版本
sed -i "s|$APP_NAME:.*|$APP_NAME:$TAG|g" docker-compose.yml

# 回滚应用版本
docker-compose up -d
로그인 후 복사

위 스크립트에서 Docker Compose 파일에 사용된 이미지 버전 번호를 직접 수정하고 컨테이너를 시작합니다.

3. 요약

이 문서에서는 컨테이너의 자동화된 배포 및 롤백을 위해 Docker를 사용하는 방법을 소개하고 몇 가지 구체적인 코드 예제를 제공합니다. 자동화된 배포를 통해 애플리케이션을 신속하게 배포 및 업데이트하고 필요한 경우 버전을 롤백하여 애플리케이션 안정성과 신뢰성을 향상시킬 수 있습니다. 그러나 실제 애플리케이션에서는 애플리케이션의 정상적인 작동을 보장하기 위해 특정 비즈니스 요구 사항 및 환경에 따라 배포 전략을 최적화해야 합니다.

위 내용은 컨테이너의 자동화된 배포 및 롤백을 위해 Docker를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿