찾다
운영 및 유지보수엔진스nginx 요청을 처리하는 방법은 무엇입니까?

nginx 요청을 처리하는 방법은 무엇입니까?

오늘은 요청에 대해 이야기하겠습니다. Nginx에서는 http 요청을 참조합니다. Nginx의 특정 데이터 구조는 ngx_http_request_t입니다. ngx_http_request_t는 http 요청을 캡슐화한 것입니다. 우리는 http 요청에 요청 라인, 요청 헤더, 요청 본문, 응답 라인, 응답 헤더 및 응답 본문이 포함된다는 것을 알고 있습니다.

http 요청은 일반적인 요청-응답 유형의 네트워크 프로토콜이고 http는 텍스트 프로토콜이므로 요청 라인과 요청 헤더를 분석하고 응답 라인과 응답 헤더를 출력하며 종종 한 줄씩 처리합니다. (추천 학습: nginx 사용)

http 서버를 직접 작성하면 일반적으로 연결이 설정된 후 클라이언트가 요청을 보냅니다. 그런 다음 데이터 라인을 읽고 요청 라인에 포함된 메서드, uri 및 http_version 정보를 분석합니다.

그런 다음 요청 헤더를 한 줄씩 처리하고 요청 방법과 요청 헤더 정보를 기반으로 요청 본문이 있는지 여부와 요청 본문의 길이를 확인한 다음 요청 본문을 읽습니다.

요청을 받은 후 요청을 처리하여 출력해야 하는 데이터를 생성한 다음 응답 라인, 응답 헤더 및 응답 본문을 생성합니다.

클라이언트에게 응답을 보낸 후 완전한 요청이 처리됩니다. 물론 이것은 가장 간단한 웹서버 처리 방법이지만 Nginx도 이 작업을 수행합니다. 예를 들어 요청 헤더를 읽으면 요청 처리가 시작됩니다. Nginx는 ngx_http_request_t를 사용하여 요청 구문 분석 및 응답 출력과 관련된 데이터를 저장합니다.

그 다음에는 Nginx가 완전한 요청을 처리하는 방법에 대해 간략하게 이야기하겠습니다. Nginx의 경우 요청은 ngx_http_init_request에서 시작됩니다. 이 함수에서는 읽기 이벤트가 ngx_http_process_request_line으로 설정됩니다. 즉, 다음 네트워크 이벤트는 ngx_http_process_request_line에 의해 실행됩니다.

ngx_http_process_request_line이라는 함수명을 보면 앞서 언급한 것처럼 요청 라인을 처리하는 일이 가장 먼저 이루어지는 것을 알 수 있습니다.

ngx_http_read_request_header를 통해 요청 데이터를 읽습니다. 그런 다음 ngx_http_parse_request_line 함수가 호출되어 요청 라인을 구문 분석합니다. 효율성을 높이기 위해 Nginx는 상태 머신을 사용하여 메서드를 비교할 때 문자열 비교를 직접 사용하지 않고 4개의 문자를 정수로 변환한 후 한 번 비교하여 CPU 명령 수를 줄입니다. . 이것은 이전에 말한 적이 있습니다.

요청 라인에 요청 메서드, URI, 버전이 포함되어 있다는 것은 많은 사람들이 알지만, 호스트도 포함될 수 있다는 사실은 모릅니다. 예를 들어 GET http://www.taobao.com/uri HTTP/1.0과 같은 요청도 합법적이며 호스트는 www.taobao.com입니다. 이때 Nginx는 요청 헤더의 호스트 필드를 무시합니다. 요청 라인에서 이것을 사용하여 가상 호스트를 찾으십시오.

또한 http0.9 버전의 경우 요청 헤더가 지원되지 않으므로 여기서 특별한 처리가 필요합니다. 따라서 나중에 요청 헤더를 구문 분석할 때 프로토콜 버전은 1.0 또는 1.1이 됩니다. 전체 요청 라인에서 파싱된 매개변수는 ngx_http_request_t 구조에 저장됩니다.

요청 라인을 구문 분석한 후 Nginx는 읽기 이벤트의 핸들러를 ngx_http_process_request_headers로 설정하고 후속 요청은 ngx_http_process_request_headers에서 읽고 구문 분석합니다.

ngx_http_process_request_headers 함수는 요청 헤더를 읽는 데 사용됩니다. 요청 헤더를 읽으려면 ngx_http_read_request_header를 호출하고, 요청 헤더 라인을 구문 분석하려면 ngx_http_parse_header_line을 호출하세요. ngx_http_request_t.headers_in은 모든 요청 헤더를 저장하는 A 연결 목록 구조입니다.

HTTP의 일부 요청에는 특별한 처리가 필요합니다. 이러한 요청 헤더와 요청 처리 기능은 ngx_http_headers_in이라는 매핑 테이블에 저장됩니다. 요청 헤더가 구문 분석되면 먼저 검색됩니다. 이 해시 테이블에서 발견되면 해당 처리 함수가 호출되어 요청 헤더를 처리합니다. 예를 들어 Host 헤더의 처리 기능은 ngx_http_process_host입니다.

Nginx가 두 개의 캐리지 리턴과 라인 피드를 구문 분석하면 요청 헤더의 끝을 나타내며 요청을 처리하기 위해 ngx_http_process_request가 호출됩니다.

ngx_http_process_request는 현재 연결의 읽기 및 쓰기 이벤트 핸들러 기능을 ngx_http_request_handler로 설정한 다음 ngx_http_handler를 호출하여 실제로 완전한 http 요청 처리를 시작합니다.

이상할 수 있습니다. 읽기 및 쓰기 이벤트 처리 함수는 모두 ngx_http_request_handler입니다. 실제로 이 함수에서는 현재 이벤트가 읽기 이벤트인지 쓰기 이벤트인지에 따라 ngx_http_request_t의 read_event_handler 또는 write_event_handler가 각각 호출됩니다.

이번에 요청 헤더를 읽었으므로 앞서 언급했듯이 Nginx는 요청 본문을 먼저 읽지 않으므로 여기에서는 read_event_handler를 ngx_http_block_reading으로 설정합니다. 즉, 데이터를 읽지 않습니다.

지금 언급한 것처럼 데이터 처리의 실제 시작은 ngx_http_handler 함수에 있습니다. 이 함수는 write_event_handler를 ngx_http_core_run_phases로 설정하고 ngx_http_core_run_phases 함수를 실행합니다.

ngx_http_core_run_phases 이 함수는 다단계 요청 처리를 수행합니다. Nginx는 http 요청 처리를 여러 단계로 나눈 다음 이 함수는 이러한 단계를 실행하여 데이터를 생성합니다.

ngx_http_core_run_phases는 결국 데이터를 생성하기 때문에 쓰기 이벤트 처리 기능이 ngx_http_core_run_phases로 설정된 이유를 쉽게 이해할 수 있습니다.

여기서는 함수의 호출 로직을 간략하게 설명합니다. 생성된 응답 헤더는 ngx_http_request_t의 headers_out에 배치됩니다. 요청 처리 과정을 살펴보세요. Nginx의 다양한 단계에서는 요청을 처리하고 마지막으로 필터를 호출하여 데이터를 필터링하고 잘린 전송, gzip 압축 등과 같은 데이터를 처리합니다.

여기의 필터에는 응답 헤더 또는 응답 본문을 처리하는 헤더 필터와 본문 필터가 포함됩니다. 필터는 헤더 필터와 바디 필터가 각각 있는 연결 리스트 구조입니다. 헤더 필터의 모든 필터가 먼저 실행되고 바디 필터의 모든 필터가 실행됩니다.

헤더 필터의 마지막 필터, 즉 ngx_http_header_filter 이 필터는 모든 응답 헤더를 순회하며 출력해야 하는 최종 응답 헤더는 연속 메모리에 있으며 출력을 위해 ngx_http_write_filter를 호출합니다.

ngx_http_write_filter는 본문 필터의 마지막 항목이므로 Nginx의 첫 번째 본문 정보는 일련의 본문 필터를 거친 후 최종적으로 출력을 위해 ngx_http_write_filter를 호출합니다(설명할 그림이 있습니다).

여기서 Nginx는 전체 요청 헤더를 버퍼에 넣습니다. 이 버퍼의 크기는 구성 항목 client_header_buffer_size를 통해 설정됩니다. 사용자의 요청 헤더가 너무 커서 버퍼가 맞지 않으면 Nginx가 다시 시작됩니다. 요청 헤더를 보관할 새로운 더 큰 버퍼를 할당합니다. 이 큰 버퍼는 Large_client_header_buffers를 통해 설정할 수 있습니다. 예를 들어 48k를 구성하는 것은 4개의 8k 버퍼를 사용할 수 있음을 의미합니다.

요청 라인 또는 요청 헤더의 무결성을 유지하려면 전체 요청 라인 또는 요청 헤더가 연속 메모리에 배치되어야 합니다. 따라서 전체 요청 라인 또는 요청 헤더는 하나의 버퍼에만 저장됩니다. . 안에.

이런 방식으로 요청 라인이 버퍼 크기보다 크면 414 오류가 반환됩니다. 요청 헤더 크기가 버퍼 크기보다 크면 400 오류가 반환됩니다. 애플리케이션 시나리오에서 이러한 매개변수의 값과 Nginx의 실제 사례를 이해한 후 프로그램을 최적화하기 위해 실제 필요에 따라 이러한 매개변수를 조정해야 합니다.

처리 흐름도:

nginx 요청을 처리하는 방법은 무엇입니까?

위는 Nginx의 http 요청 수명 주기입니다.

위 내용은 nginx 요청을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

NGINX는 이벤트 중심 아키텍처 및 비동기 처리 기능을 통해 성능을 향상시키고 모듈 식 설계 및 유연한 구성을 통해 확장 성을 향상 시키며 SSL/TLS 암호화 및 요청 속도 제한을 통해 보안을 향상시킵니다.

Nginx vs. Apache : 웹 호스팅 및 트래픽 관리Nginx vs. Apache : 웹 호스팅 및 트래픽 관리Apr 12, 2025 am 12:04 AM

NGINX는 동시성이 높은 자원 소비 시나리오에 적합하지만 APACHE는 복잡한 구성 및 기능 확장이 필요한 시나리오에 적합합니다. 1.NGINX는 고성능과의 많은 동시 연결을 처리하는 것으로 알려져 있습니다. 2. Apache는 안정성과 풍부한 모듈 지원으로 유명합니다. 선택할 때는 특정 요구에 따라 결정해야합니다.

NGINX : 최신 웹 애플리케이션을위한 다목적 도구NGINX : 최신 웹 애플리케이션을위한 다목적 도구Apr 11, 2025 am 12:03 AM

nginxissentialderformodernwebapplicationsduetoitsrolessareareverseproxy, loadbalancer 및 Webserver, HighperformanceAndscalability를 제공합니다

Nginx SSL/TLS 구성 : HTTPS로 웹 사이트 보안Nginx SSL/TLS 구성 : HTTPS로 웹 사이트 보안Apr 10, 2025 am 09:38 AM

Nginx를 통해 웹 사이트 보안을 보장하려면 다음 단계가 필요합니다. 1. 기본 구성을 만들고 SSL 인증서 및 개인 키를 지정하십시오. 2. 구성 최적화, HTTP/2 및 OCSPStapling 활성화; 3. 인증서 경로 및 암호화 제품군 문제와 같은 공통 오류 디버그; 4. Let 'sencrypt 및 세션 멀티플렉싱 사용과 같은 응용 프로그램 성능 최적화 제안.

Nginx 인터뷰 질문 : ACE 귀하의 DevOps/System Admin 인터뷰Nginx 인터뷰 질문 : ACE 귀하의 DevOps/System Admin 인터뷰Apr 09, 2025 am 12:14 AM

NGINX는 고성능 HTTP 및 리버스 프록시 서버로 높은 동시 연결을 처리하는 데 능숙합니다. 1) 기본 구성 : 포트를 듣고 정적 파일 서비스를 제공합니다. 2) 고급 구성 : 리버스 프록시 및로드 밸런싱을 구현하십시오. 3) 디버깅 기술 : 오류 로그를 확인하고 구성 파일을 테스트하십시오. 4) 성능 최적화 : GZIP 압축을 활성화하고 캐시 정책을 조정합니다.

Nginx 캐싱 기술 : 웹 사이트 성능 향상Nginx 캐싱 기술 : 웹 사이트 성능 향상Apr 08, 2025 am 12:18 AM

Nginx 캐시는 다음 단계를 통해 웹 사이트 성능을 크게 향상시킬 수 있습니다. 1) 캐시 영역을 정의하고 캐시 경로를 설정하십시오. 2) 캐시 유효성 기간 구성; 3) 다른 컨텐츠에 따라 다른 캐시 정책을 설정합니다. 4) 캐시 저장 및로드 밸런싱을 최적화합니다. 5) 캐시 효과를 모니터링하고 디버그합니다. 이러한 방법을 통해 NGINX 캐시는 백엔드 서버 압력을 줄이고 응답 속도 및 사용자 경험을 향상시킬 수 있습니다.

Docker와 Nginx : 컨테이너화 된 응용 프로그램을 배포하고 스케일링합니다Docker와 Nginx : 컨테이너화 된 응용 프로그램을 배포하고 스케일링합니다Apr 07, 2025 am 12:08 AM

dockercompose를 사용하면 Nginx의 배포 및 관리를 단순화 할 수 있으며 Dockerswarm 또는 Kubernetes를 통한 스케일링은 일반적인 관행입니다. 1) DockerCompose를 사용하여 Nginx 컨테이너를 정의하고 실행하십시오. 2) Dockerswarm 또는 Kubernetes를 통한 클러스터 관리 및 자동 스케일링 구현.

고급 NGINX 구성 : 서버 블록 마스터 링 및 리버스 프록시고급 NGINX 구성 : 서버 블록 마스터 링 및 리버스 프록시Apr 06, 2025 am 12:05 AM

NGINX의 고급 구성은 서버 블록 및 리버스 프록시를 통해 구현 될 수 있습니다. 1. 서버 블록을 사용하면 여러 웹 사이트를 한쪽으로 실행할 수있게되면 각 블록은 독립적으로 구성됩니다. 2. 리버스 프록시는 요청을 백엔드 서버로 전달하여로드 밸런싱 및 캐시 가속도를 실현합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기