>  기사  >  백엔드 개발  >  PHP 500 오류 문제를 해결하는 방법

PHP 500 오류 문제를 해결하는 방법

藏色散人
藏色散人원래의
2021-12-29 09:30:2912430검색

PHP 500 오류 해결 방법: 1. PHP 스크립트를 확인하고 수정합니다. 2. 예외를 캡처하고 로그에 기록합니다. 3. 로그를 분석하고 처리합니다.

PHP 500 오류 문제를 해결하는 방법

이 문서의 운영 환경: Windows 7 시스템, PHP 버전 7.1, Dell G3 컴퓨터.

PHP 500 오류 문제는 어떻게 해결하나요?

PHP 및 500 오류

PHP 개발 과정에서 500 오류가 자주 반환되고, 본문에 디버깅(사용 가능한) 내용이 없습니다. 이때 천천히 디버깅(중단점, 디버깅 모드 켜기 등)을 해야 하지만, 라이브 네트워크라면 이 오류로 인해 중단점을 설정하거나 디버깅 모드를 켜는 것이 쉽지 않습니다. 하지만 오류이기 때문에 해결책은 항상 있기 마련입니다. 500의 원인과 해결책을 단계별로 분석해 보겠습니다.

0x01, 500 오류

500 오류(내부 서버 오류(내부 서비스 오류)라고도 함)는 알 수 없는 오류로 인해 서비스가 요청을 처리할 수 없음을 의미합니다. PHP 사이트에서는 일반적으로 PHP에 의해 반환됩니다. 즉, 500 오류는 일반적으로 PHP 스크립트의 오류입니다.

PHP 500 오류 문제를 해결하는 방법

php-fpm 캡처 패킷 500

위 그림에서 볼 수 있듯이(Nginx+PHP-FPM 아키텍처), PHP가 존재하지 않는 클래스를 호출하면 스크립트 오류가 발생하고 Nginx에 500을 반환합니다. 오류 메시지도 반환되지만 STDERR에서 언로드됩니다.

0x02, 어떤 오류 예외가 500

그러면 어떤 종류의 오류로 인해 500 오류가 발생할까요? PHP의 모든 오류 수준은 PHP 공식 문서(http://php.net/manual/zh/errorfunc)에서 확인할 수 있습니다. .constants.php), E_ERROR, E_PARSE, E_RECOVERABLE_ERROR, E_USER_ERROR 및 포착되지 않은 예외의 오류 수준은 모두 500 오류를 발생시킵니다.

PHP 500 오류 문제를 해결하는 방법

500

0x03으로 인해 발생하는 E_ERROR 수준 오류, 어떤 상황에서는 500

을 반환하지 않는 오류는 위에서 언급한 것처럼 PHP 스크립트의 오류로 인해 발생하지만 오류가 있거나 PHP 스크립트에서 예외가 발생하면 확실히 원인 500이 발생할까요? 분명히 그렇지는 않습니다. 스크립트에 치명적인 오류가 있더라도 여전히 200을 반환할 수 있습니다.

PHP 500 오류 문제를 해결하는 방법

display_errors 구성 옵션

Python, nodejs 등을 기반으로 하는 웹 애플리케이션에서는 기본적으로 예외 메시지가 발생하면 콘솔(STDERR/STDOUT)에 출력됩니다. PHP-FPM 아키텍처를 기반으로 하는 PHP에는 인쇄할 콘솔이 없으며 해당 stderr 및 stdout은 FastCGI의 해당 STDERR 및 STDOUT으로 설정됩니다. 오류가 STDOUT으로 리디렉션되면 오류가 응답으로 직접 출력되고 상태 코드는 200으로 설정됩니다. 이는 display_errors 옵션을 통해 얻을 수 있는 기능이기도 합니다.

display_errors 옵션의 구성은 ini_set을 통해 구현되어야 합니다. PHP 문서의 display_errors 구성은 값이 문자열 유형임을 나타냅니다. 실제 사용에서는 숫자 및 부울 유형도 이 구성을 켜거나 끌 수 있습니다.

PHP 500 오류 문제를 해결하는 방법

error_reporting 구성

display_errors는 PHP 스크립트에서 오류가 발생할 때 오류 세부 정보를 표시할지 여부와 오류 상태 코드를 반환할지 여부를 제어하는 ​​반면, error_reporting 항목은 직접 인쇄할 수 있는 오류 수준을 제어하는 ​​데 사용됩니다.

error_reporting의 설정 항목은 error_reporting(E_ALL) 또는 ini_set('error_reporting', E_ALL)을 통해 구성할 수 있습니다. 함수 매개변수에 대한 자세한 내용은 PHP 설명서를 참조하세요.

PHP 자체에는 오류 로그(2개의 구성 항목, error_log 및 log_errors)가 있다는 점에 유의해야 합니다. 오류가 발생하면 PHP는 오류 로그에 오류를 기록합니다. 어떤 오류를 기록해야 하는지는 error_reporting 항목에 영향을 받습니다. 통제의.

PHP 500 오류 문제를 해결하는 방법

오류 수준이 일치하지 않을 때 오류 내용을 표시하지 않음

0x04, 기존 네트워크에서 500을 합리적으로 처리하는 방법

500 오류가 발생하면 PHP 스크립트가 정상적으로 실행될 수 없음을 알 수 있으며, 현재 수행할 수 있는 작업은 예외를 캡처하고 로그에 기록하여 향후 디버깅 및 라이브 네트워크 버그 처리를 용이하게 하는 것뿐입니다.


PHP에는 오류 로그가 함께 제공됩니다

PHP 자체에는 이미 오류 로그 기록이 있습니다. php.ini에서 log_errors 항목을 On으로 설정하고 error_log 구성 항목과 협력하여 오류 로그의 저장 경로를 지정할 수 있습니다. .

PHP 500 오류 문제를 해결하는 방법

오류 로깅 스위치

PHP 500 오류 문제를 해결하는 방법

로그 경로 설정

이 오류 로그 작성은 display_errors 구성에 의해 제어되지 않습니다. 즉, display_errors가 켜져 있는지 여부에 관계없이 오류가 로그에 기록됩니다. 그러나 현재 오류 수준이 error_reporting의 오류 수준과 일치하지 않으면 오류가 로그에 기록되지 않습니다. 즉, 오류 수준이 E_ERROR인데 설정이 error_reporting(E_NOTICE)인 경우 E_ERROR 오류 메시지가 로그에 나타나지 않습니다.

PHP 500 오류 문제를 해결하는 방법

PHP 오류 로그에는 다양한 유형의 오류가 기록됩니다.

PHP 500 오류 문제를 해결하는 방법

오류 수준 불일치로 인해 로그가 기록되지 않습니다.

오류 예외 기록 캡처

PHP는 set_error_handler, Register_shutdown_function, set_Exception_handler, error_get_last 및 기타 관련 관련 오류를 제공합니다. 처리 기능. 오류 기록은 캡처된 오류 정보를 함수를 통해 지정된 로그에 기록하여 수행할 수 있습니다.

기능 사용에 대한 자세한 내용은 http://km.oa.com/group/19368/articles/show/302491을 참조하세요. 템플릿은 다음과 같습니다.

$previousHandler = set_exception_handler(function(Exception $ex) use (&$previousHandler) {
    call_user_func('exceptionHandler', $ex, $previousHandler);
});
set_error_handler('errorHandler');
register_shutdown_function('fatalErrorHandler');
function exceptionHandler(Exception $ex, $previousHandler)
{
    $info = array(
        $ex->getFile(),
        $ex->getLine(),
        $ex->getCode(),
        $ex->getMessage()
    );
    // 记录日志
    logPHPError($info);
    if (isset($previousHandler) && is_callable($previousHandler)) {
        call_user_func($previousHandler, $ex);
    }
}
/**
 * 框架错误处理函数
 * @param $errno
 * @param $errstr
 * @param $errfile
 * @param $errline
 * @return bool
 */
function errorHandler($errno = 0, $errstr = '', $errfile = '', $errline = 0)
{
    switch ($errno) {
        case E_WARNING:
            $errname = 'E_WARNING';
            break;
        case E_NOTICE:
            $errname = 'E_NOTICE';
            break;
        case E_STRICT:
            $errname = 'E_STRICT';
            break;
        case E_RECOVERABLE_ERROR:
            $errname = 'E_RECOVERABLE_ERROR';
            break;
        case E_DEPRECATED:
            $errname = 'E_DEPRECATED';
            break;
        case E_USER_ERROR:
            $errname = 'E_USER_ERROR';
            break;
        case E_USER_WARNING:
            $errname = 'E_USER_WARNING';
            break;
        case E_USER_NOTICE:
            $errname = 'E_USER_NOTICE';
            break;
        case E_USER_DEPRECATED:
            $errname = 'E_USER_DEPRECATED';
            break;
        default:
            restore_error_handler();
            return false;
    }
    // 记录日志
    $info = array(
        $errfile,
        $errline,
        $errname,
        $errstr
    );
    logPHPError($info);
    restore_error_handler();
    return false;
}
/**
 * Fatal error错误处理
 */
function fatalErrorHandler()
{
    if (($e = error_get_last()) && $e['type'] === E_ERROR) {
        $info = array(
            $e['file'],
            $e['line'],
            'E_ERROR',
            $e['message']
        );
        // 记录日志
        logPHPError($info);
    }
}

0x05 Summary

To sum up에서 error_reporting은 브라우저나 PHP 오류 로그에 오류 정보 수준을 출력하는 함수 또는 구성을 제어하는 ​​데 사용되며, display_errors는 오류 및 경고 정보를 브라우저에 출력할지 여부를 제어합니다.

PHP의 오류 로그는 전역적이며 error_reporting에 의해 제어되므로 비즈니스에서 자체 오류(예외) 캡처 및 기록 논리를 구현하는 것이 좋습니다.

추천 학습: "PHP 비디오 튜토리얼"

위 내용은 PHP 500 오류 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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