> 운영 및 유지보수 > 엔진스 > nginx에서 PHP 플러시 실패 문제를 해결하는 방법

nginx에서 PHP 플러시 실패 문제를 해결하는 방법

王林
풀어 주다: 2020-11-11 15:43:43
앞으로
2195명이 탐색했습니다.

nginx에서 PHP 플러시 실패 문제를 해결하는 방법

Problem

PHP를 한 줄씩 출력해 디버깅을 하다가 ob_flush와 Flush가 모두 실패한 것을 발견했습니다. phpinfo를 통해 기본적으로 php.ini의 설정이 정상인지 판단할 수 있습니다.

(동영상 공유 학습: php 동영상 튜토리얼)

해결책

Nginx를 다시 살펴보고 Nginx에 다음 설정이 있는지 확인하세요.

fastcgi_buffer_size 128k;
fastcgi_buffers 8 128k;
로그인 후 복사

문제는 기본적으로 Nginx가 PHP에서 출력하는 정보를 버퍼링하는 것입니다. 버퍼 데이터는 128k에 도달할 때까지 클라이언트로 전송되지 않습니다. 그런 다음 먼저 다음과 같이 버퍼 크기를 줄여야 합니다.

fastcgi_buffer_size 4k;
fastcgi_buffers 8 4k;
로그인 후 복사

그리고 gzip을 비활성화해야 합니다

gzip off;
로그인 후 복사

그런 다음 PHP에서 ob_flush 및 플러시 전에 , 최대 4k의 콘텐츠를 출력합니다. 예:

echo str_repeat(‘ ‘, 1024*4);
로그인 후 복사

이 시점에서 PHP는 일반적으로 ob_flush 및 플러시를 통해 필요한 콘텐츠를 한 줄씩 출력할 수 있습니다.

관련 권장 사항: nginx 튜토리얼

위 내용은 nginx에서 PHP 플러시 실패 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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