>운영 및 유지보수 >리눅스 운영 및 유지 관리 >컨테이너 오류 복구 및 자동 재시작을 위해 Docker를 사용하는 방법

컨테이너 오류 복구 및 자동 재시작을 위해 Docker를 사용하는 방법

WBOY
WBOY원래의
2023-11-07 16:28:471194검색

컨테이너 오류 복구 및 자동 재시작을 위해 Docker를 사용하는 방법

Docker는 컨테이너 기술을 기반으로 한 경량 가상화 플랫폼으로 다양한 시나리오에서 널리 사용되었습니다. 프로덕션 환경에서는 컨테이너의 고가용성과 자동 장애 복구가 중요합니다. 이 문서에서는 특정 코드 예제를 포함하여 컨테이너 오류 복구 및 자동 다시 시작을 위해 Docker를 사용하는 방법을 소개합니다.

1. 자동 컨테이너 재시작 구성

Docker에서는 컨테이너 실행 시 --restart 옵션을 사용하여 컨테이너 자동 재시작 기능을 활성화할 수 있습니다. 일반적인 옵션은 다음과 같습니다.

  • no: 자동으로 다시 시작하지 않습니다. 기본 옵션
  • 항상: 항상 자동으로 다시 시작합니다.
  • on-failure: 0이 아닌 상태로 인해 컨테이너가 종료될 때만 자동으로 다시 시작합니다.
  • 중지되지 않은 경우: 수동으로 중지하지 않는 한 항상 자동으로 다시 시작합니다.

다음은 --restart 옵션을 사용하여 자동 컨테이너 다시 시작을 활성화하는 예입니다.

docker run -d --restart Always nginx

이 예에서는 nginx라는 Docker 컨테이너를 시작하고 컨테이너를 항상 구성하도록 구성합니다. --restart 옵션을 통해 자동으로 다시 시작합니다.

--restart 옵션은 실패로 인해 컨테이너가 종료될 때만 적용된다는 점에 유의해야 합니다. 컨테이너가 수동으로 중지되면 자동으로 다시 시작되지 않습니다. 컨테이너가 수동으로 중지된 후에도 자동 다시 시작을 활성화하려는 경우 unstopped 옵션을 사용할 수 있습니다.

2. 컨테이너 오류 복구 구성

Docker에서 컨테이너 오류 복구는 일반적으로 서비스 가용성을 보장하기 위해 Docker Swarm과 같은 클러스터 관리 도구를 사용하여 컨테이너 일정을 자동으로 변경하는 것을 의미합니다. 다음은 Docker Swarm에서 자동 장애 조치를 구성하는 방법을 보여주는 예입니다.

  1. Docker Swarm 클러스터 만들기:

docker swarm init

  1. 클러스터에서 서비스 만들기:

docker service create --name nginx --replicas 3 nginx

이 예에서는 nginx라는 서비스를 만들고 복제본 수를 3으로 설정합니다.

  1. 서비스에서 오류 복구 활성화:

docker service update --update-delay 10s --update-parallelism 2 --update-failure-action restart nginx

여기에 지정된 --update-delay 옵션 지연 업데이트 작업 사이의 시간 --update-parallelism 옵션은 각 업데이트에 대한 동시 인스턴스 수를 지정합니다. --update-failure-action 옵션은 업데이트가 실패할 때 수행할 작업을 지정합니다. 여기서는 컨테이너를 다시 시작하도록 설정합니다. .

오류 복구 기능은 Docker Swarm과 같은 클러스터 관리 도구를 사용할 때만 적용된다는 점에 유의하세요. docker run 명령을 직접 사용하여 컨테이너를 시작하는 경우 --restart 옵션만 사용하여 컨테이너를 자동으로 다시 시작할 수 있습니다.

3. 컨테이너 오류 복구 및 자동 다시 시작을 위한 코드 예제

다음은 --restart 옵션과 Docker Swarm과 같은 클러스터 관리 도구를 사용하여 컨테이너 오류 복구 및 자동 다시 시작을 구현하는 방법을 보여주는 전체 코드 예제입니다.

    docker-demo라는 Docker Swarm 클러스터를 만듭니다.
docker swarm init --advertise-addr 127.0.0.1

    클러스터에 nginx라는 서비스를 만들고 복제본 수를 각각 3으로 설정합니다.
docker service create --name nginx --replicas 3 nginx

    서비스에서 오류 복구 활성화:
docker service update --update-delay 10s --update-parallelism 2 --update- failure-action restart nginx

    잠시 기다린 후 수동으로 컨테이너 중지:
docker 컨테이너 중지

    잠깐 기다린 후 컨테이너가 자동으로 다시 시작되는지 확인:
docker 컨테이너 ls

컨테이너가 자동으로 다시 시작되면 해당 상태는 실행 중이어야 합니다.

컨테이너 오류 복구 및 자동 다시 시작의 구체적인 구현 방법은 다르며, 시나리오에 따라 구현하려면 다른 방법이 필요하다는 점에 유의해야 합니다. 위의 예는 참고용일 뿐이며 실제 상황에 따라 구체적인 구현을 조정해야 합니다.

요약

컨테이너 오류 복구 및 자동 다시 시작은 Docker 컨테이너의 고가용성을 보장하는 중요한 수단입니다. Docker의 자동 재시작 및 장애 복구 기능을 올바르게 구성하면 컨테이너 장애로 인한 서비스 중단 시간을 효과적으로 줄일 수 있습니다. 이 문서에서는 --restart 옵션과 Docker Swarm과 같은 클러스터 관리 도구를 사용하여 컨테이너 오류 복구 및 자동 다시 시작 기능을 구현하는 방법을 설명하고 구체적인 코드 예제를 제공합니다. 이 글이 Docker를 사용하는 모든 분들에게 도움이 되기를 바랍니다.

위 내용은 컨테이너 오류 복구 및 자동 재시작을 위해 Docker를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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