>  기사  >  운영 및 유지보수  >  Nginx 서버의 상태 점검 및 자동 장애 복구에 대한 자세한 설명

Nginx 서버의 상태 점검 및 자동 장애 복구에 대한 자세한 설명

PHPz
PHPz원래의
2023-08-05 23:40:443586검색

Nginx 서버의 상태 확인 및 자동 오류 복구에 대한 자세한 설명

소개:
오늘날의 인터넷 애플리케이션에서는 높은 동시성 및 고가용성이 매우 중요합니다. 시스템의 안정성을 보장하기 위해서는 서버의 상태를 모니터링하고 확인하여 자동으로 장애 복구를 수행해야 합니다. 이 글에서는 상태 확인 및 자동 장애 복구를 위해 Nginx 서버를 사용하는 방법을 자세히 설명하고 관련 코드 예제를 제공합니다.

  1. Nginx 상태 확인 원칙
    Nginx 구성 파일에서 업스트림 모듈을 통해 백엔드 서버 그룹을 정의할 수 있으며 Nginx는 특정 알고리즘에 따라 요청을 다른 서버에 할당합니다. 이 프로세스 동안 Nginx는 백엔드 서버의 상태를 확인하여 요청 배포를 동적으로 조정할 수 있습니다. 일반적으로 사용되는 상태 확인 방법에는 두 가지가 있습니다.

1.1 활성 상태 확인:
Nginx는 주기적으로 백엔드 서버에 요청을 보낸 다음 반환된 상태 코드를 기반으로 서버의 상태를 확인합니다. 반환된 상태 코드가 서버가 정상임을 나타내면 Nginx는 해당 서버를 사용 가능한 서버 목록에 추가합니다. 반환된 상태 코드가 서버가 비정상임을 나타내면 Nginx는 사용 가능한 서버 목록에서 해당 서버를 제거합니다.

1.2 수동 상태 확인:
Nginx가 백엔드 서버에 요청을 보내고 연결 시간이 초과되거나 요청이 실패하면 Nginx는 해당 서버를 사용할 수 없는 서버로 판단하고 사용 가능한 서버 목록에서 제거합니다. 새 요청이 도착하면 Nginx는 사용 가능한 다른 서버에 연결을 시도합니다.

  1. Nginx 헬스 체크 구성 예시
    Nginx 구성 파일에서 업스트림 모듈의 health_check 매개변수를 통해 헬스 체크 기능을 활성화하고 관련 헬스 체크 항목을 구성할 수 있습니다. 다음은 샘플 구성입니다.

http {

upstream backend {
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com;
    
    # 开启健康检查功能
    health_check;
    
    # 配置健康检查项
    health_check_timeout 3s;
    health_check_interval 10s;
    health_check_http_2xx;
    health_check_http_3xx;
}

server {
    listen 80;
    
    location / {
        proxy_pass http://backend;
    }
}

}

위 구성에서는 backend라는 업스트림 그룹을 정의하고 3개의 백엔드 서버를 구성했습니다. health_check 파라미터를 on으로 설정하면 헬스 체크 기능이 활성화됩니다. 헬스 체크 항목의 구체적인 구성은 다음과 같습니다.

  • health_check_timeout: 헬스 체크의 타임아웃을 설정합니다.
  • health_check_interval: 상태 확인 간격을 설정합니다.
  • health_check_http_2xx: 반환된 상태 코드가 2xx(예: 200)인 경우 서버가 정상임을 의미합니다.
  • health_check_http_3xx: 반환된 상태 코드가 3xx(예: 301, 302)인 경우 서버가 정상임을 의미합니다.
  1. Nginx 자동 장애 복구 구성 예시
    Nginx는 상태 점검 외에도 자동 장애 복구 기능도 제공합니다. 백엔드 서버를 사용할 수 없다고 판단되면 Nginx는 해당 서버를 사용 가능한 서버 목록에서 자동으로 제거하고 일정 시간 후에 다시 상태 점검을 수행합니다. 백엔드 서버가 상태 확인을 통과하면 Nginx는 이를 사용 가능한 서버 목록에 다시 추가하여 자동 오류 복구를 수행합니다. 다음은 구성 예시입니다.

http {

upstream backend {
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com;
    
    # 开启健康检查和自动故障恢复功能
    health_check;
    max_fails 3;
    fail_timeout 30s;
    
    # 配置健康检查项
    health_check_timeout 3s;
    health_check_interval 10s;
    health_check_http_2xx;
    health_check_http_3xx;
}

server {
    listen 80;
    
    location / {
        proxy_pass http://backend;
    }
}

}

위 구성에서는 max_fails, failure_timeout 두 개의 매개변수를 추가하여 자동 장애 복구 기능을 구성했습니다.

  • max_fails: 특정 기간(fail_timeout 매개변수로 지정) 내 최대 실패 횟수를 설정합니다. 기본적으로 1회입니다.
  • fail_timeout: 오류 복구 시간 제한을 설정합니다.

백엔드 서버의 실패 횟수가 max_fails에 구성된 값에 도달하면 Nginx는 사용 가능한 서버 목록에서 서버를 제거하고 failure_timeout에 구성된 제한 시간 이후에 다시 상태 확인을 수행합니다. 서버가 상태 확인을 통과하면 Nginx는 이를 사용 가능한 서버 목록에 다시 추가합니다.

결론:
Nginx 서버의 상태 점검 및 자동 오류 복구 기능은 시스템의 안정성과 가용성을 효과적으로 향상시킬 수 있습니다. 위의 구성 예를 통해 Nginx를 쉽게 구성하여 상태 확인 및 자동 장애 복구 기능을 구현할 수 있습니다. 이 글이 Nginx 서버의 헬스 체크와 자동 장애 복구 기능을 이해하고 활용하는 데 도움이 되기를 바랍니다.

위 내용은 Nginx 서버의 상태 점검 및 자동 장애 복구에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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