>  기사  >  백엔드 개발  >  PHP 작동 방식의 기본

PHP 작동 방식의 기본

不言
不言원래의
2018-07-04 16:43:272084검색

이 글은 주로 PHP 작동 원리의 기본을 소개합니다. 이제 특정 참고 가치가 있습니다. 도움이 필요한 친구들이 참고할 수 있습니다.

최근에 구축했습니다. 서버를 방문하고 갑자기 느꼈습니다. 램프는 어떻게 작동하며 어떻게 연결되어 있나요? 나는 보통 프로그램을 작성하고 그 사이의 작동 원리에 대해 생각해 본 적이 없습니다.

PHP 기본 작동 원리

그림 1 PHP 구조

그림에서 볼 수 있듯이 PHP는 아래에서 위로 4계층 시스템입니다

①Zend 엔진

Zend는 순수를 사용합니다 c 구현은 PHP의 핵심 부분입니다. PHP 코드(어휘, 구문 분석 및 기타 컴파일 프로세스)를 실행 가능한 opcode 처리로 변환하고 해당 처리 방법을 구현하며 기본 데이터 구조(예: 해시 테이블, oo), 메모리 할당 및 관리를 구현합니다. , 모든 것의 핵심인 외부 호출에 해당하는 API 메소드를 제공하며 모든 주변 기능은 zend를 중심으로 구현됩니다.

②Extensions

zend 엔진 주변에서 확장 프로그램은 일반적인 다양한 내장 기능(예: 어레이 시리즈), 표준 기능을 포함하여 구성 요소 기반 방식으로 다양한 기본 서비스를 제공합니다. 라이브러리 등 모두 확장을 통해 구현됩니다. 사용자는 기능 확장, 성능 ​​최적화 등을 달성하기 위해 필요에 따라 자체 확장을 구현할 수도 있습니다. 예를 들어 현재 Tieba에서 사용하는 PHP 중간 계층 및 서식 있는 텍스트 구문 분석은 확장의 일반적인 응용 프로그램입니다. ).

③Sapi

Sapi의 전체 이름은 서버 응용 프로그램 프로그래밍 인터페이스입니다. Sapi는 일련의 후크 기능을 사용하여 PHP가 주변 장치와 상호 작용할 수 있도록 합니다. 이는 PHP가 SAPI를 통해 성공적으로 상위 계층 응용 프로그램과 분리되고 격리된 디자인입니다. PHP는 더 이상 다른 응용 프로그램과 호환되는 방법을 고려할 수 없으며 응용 프로그램 자체도 구현할 수 있습니다. 자체 특성에 따라 처리 방법이 다릅니다. 나중에 sapi 장에서 소개하겠습니다

4상위 계층 응용 프로그램

이것은 우리가 일반적으로 작성하는 PHP 프로그램이며, 다양한 sapi 방법을 통해 다양한 응용 모드를 얻을 수 있으며, 예를 들어 웹 서버를 통해 웹 애플리케이션을 구현하고 명령줄에서 스크립트로 실행하는 등의 작업을 수행합니다.

건축적 아이디어:

엔진(Zend) + 컴포넌트(ext) 모델로 내부 결합 감소

Middle 레이어(sapi)는 웹 서버와 php

************************************를 격리합니다. *** *****************************************

#🎜 🎜#php가 자동차라면

자동차의 프레임워크는 PHP 그 자체

Zend는 자동차의 엔진(엔진)

#🎜🎜 #Ext 다양한 따라하기 구성요소는 자동차의 바퀴

사피는 도로라고 할 수 있고, 자동차는 다양한 도로를 달릴 수 있다

그리고 실행은 PHP 프로그램은 도로를 달리는 자동차와 같습니다.

따라서 다음이 필요합니다: 뛰어난 성능의 엔진 + 적합한 바퀴 + 올바른 활주로

아파치와 PHP의 관계

#🎜 🎜#Apache의 PHP 파싱은 여러 모듈 중 php 모듈을 통해 완성됩니다.

마지막으로 PHP를 Apache 시스템에 통합하려면 Apache에 필요한 몇 가지 설정을 지정해야 합니다. 여기서는 php의 mod_php5 SAPI 동작 모드를 예로 들어 설명하겠습니다. SAPI의 개념에 대해서는 나중에 자세히 설명하겠습니다.

설치한 버전이 Apache2 및 Php5라고 가정하면 Apache의 기본 구성 파일인 http.conf를 편집하고 다음 줄을 추가해야 합니다.

Unix/Linux 환경:

LoadModule php5_module module/mod_php5.so

AddType application/x-httpd-php .php

참고: 그중에 module/mod_php5 .so는 X 시스템 환경에서 mod_php5.so 파일의 설치 위치입니다.

Windows 환경에서:

LoadModule php5_module d:/php/php5apache2.dll

AddType application/x-httpd-php .php#🎜 🎜#

참고: d:/php/php5apache2.dll은 Windows 환경에서 php5apache2.dll 파일의 설치 위치입니다.

이 두 구성은 앞으로 수신되는 모든 URL 사용자 요청(접미사 php 포함)이 처리를 위해 php5_module 모듈(mod_php5.so/php5apache2.dll)을 호출해야 함을 Apache 서버에 알립니다.

Apache의 수명주기

Apache의 요청 처리 프로세스

# 🎜 🎜 #

Apache 요청 처리 주기 상세 설명

Apache 요청 처리 주기의 11단계는 무엇인가요?

1. 읽기 후 요청 단계 일반적인 요청 처리 과정에서 모듈이 후크를 삽입할 수 있는 첫 번째 단계입니다. 이 단계는 요청을 매우 일찍 처리하려는 모듈에 활용될 수 있습니다.

2. URI 변환 단계

이 단계에서 Apache의 주요 작업은 요청된 URL을 로컬 파일 시스템에 매핑하는 것입니다. 모듈은 이 단계에서 후크를 삽입하여 자체 매핑 논리를 실행할 수 있습니다. mod_alias는 이 단계를 사용하여 작동합니다.

3. 헤더 구문 분석 단계
이 단계에서 Apache의 주요 작업: 요청의 헤더를 확인합니다. 모듈은 요청 처리 흐름의 어느 시점에서든 요청 헤더를 확인하는 작업을 수행할 수 있으므로 이 후크는 거의 사용되지 않습니다. mod_setenvif는 이 단계를 사용하여 작업합니다.

4. 접근 제어 단계
이 단계에서 Apache의 주요 작업: 구성 파일에 따라 요청한 리소스에 대한 접근이 허용되는지 확인합니다. Apache의 표준 논리는 허용 및 거부 지시문을 구현합니다. mod_authz_host는 이 단계를 사용하여 작동합니다.

5. 인증 단계
이 단계에서 Apache의 주요 작업은 구성 파일에 설정된 정책에 따라 사용자를 인증하고 사용자 이름 영역을 설정하는 것입니다. 모듈은 이 단계에서 후크를 삽입하여 인증 방법을 구현할 수 있습니다.

6. 인증 단계
이 단계에서 Apache의 주요 작업: 인증된 사용자가 구성 파일에 따라 요청된 작업을 수행할 수 있는지 확인합니다. 모듈은 이 단계에서 후크를 삽입하여 사용자 권한 관리 방법을 구현할 수 있습니다.

7. MIME 유형 확인 단계
이 단계에서 Apache의 주요 작업은 요청된 리소스의 MIME 유형 관련 규칙을 기반으로 사용할 콘텐츠 처리 기능을 결정하는 것입니다. 표준 모듈 mod_negotiation 및 mod_mime은 이 후크를 구현합니다.

8. FixUp 단계
이는 모듈이 콘텐츠 생성 전에 필요한 모든 처리를 실행할 수 있도록 하는 일반적인 단계입니다. Post_Read_Request와 유사하게 모든 정보를 캡처할 수 있는 후크이며 가장 일반적으로 사용되는 후크이기도 합니다.

9. 응답 단계
이 단계에서 Apache의 주요 작업은 클라이언트에 반환되는 콘텐츠를 생성하고 클라이언트에 적절한 응답을 보내는 것입니다. 이 단계는 전체 프로세스의 핵심 부분입니다.

10. 로깅 단계
이 단계에서 Apache의 주요 작업은 응답이 클라이언트에 전송된 후 트랜잭션을 기록하는 것입니다. 모듈은 Apache의 표준 로깅을 수정하거나 대체할 수 있습니다.

11. 정리 단계
이 단계에서 Apache의 주요 작업: 파일 및 디렉터리 처리 또는 소켓 닫기 등 이 요청 트랜잭션이 완료된 후 남은 환경을 정리합니다. 이것이 마지막 단계입니다. Apache의 요청 처리.

LAMP 아키텍처:

아래에서 위로 4개의 레이어:

①liunx는 운영 체제의 맨 아래 레이어에 속합니다.

②apache 서버는 보조 서버이며 Linux 및 PHP와 통신합니다.

③php : php_module 모듈

을 통해 Apache와 연결되는 서버 측 프로그래밍 언어에 속합니다. ④mysql 및 기타 웹 서비스: PHP의 확장 플러그인 모듈을 통해 mysql과 연결되는 애플리케이션 서비스에 속합니다.

Android 시스템 아키텍처 다이어그램

램프와 안드로이드의 아키텍처 다이어그램을 비교해 보면 램프 아키텍처와 비슷한 것 같습니다. 안드로이드는 모르지만 약간 비슷한 느낌이 듭니다. 전문가들은 차이점을 지적해 주실 수 있습니다.

위에서 아래로:

Android 아키텍처------------ --설명---------LAMP 아키텍처

1. 특정 애플리케이션---------웹 애플리케이션

2. 애플리케이션 프레임워크---- java------------PHP 언어 및 라이브러리

3. --가상 머신---------웹 서버

⒋Linux 커널: -- -운영 체제---------램프 아키텍처의 L

램프와 컴퓨터 내부의 관계

CPU는 공장, 하드디스크는 대형 창고, 메모리는 일반 전송 센터, 가상 메모리는 임시 전송 센터

PHP 언어는 zend에 의해 기계어로 컴파일되는 연산입니다. 데이터베이스의 CPU

는 I/O 작업이며 기계적 이동입니다. 즉, 웹 사이트의 병목 현상은 하드 디스크에 대한 읽기 및 쓰기로 인해 발생합니다. 버퍼링 기술은 데이터 작업이 Mencache에 배치되고 특정 크기에 도달하면 즉시 데이터베이스에 기록된다는 것을 의미합니다. Mencache는 관계형 데이터가 아닌 키-값 관계

에 속합니다. 이것도 이 개념을 기반으로 만들어졌습니다. , 또한 키-값 관계에 속합니다

빈번한 읽기 작업------mencache에 넣습니다

더 많이 읽고 적게 씁니다------nosql에 넣습니다- -----읽기 기능이 매우 강력합니다!

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 추천:

PHP 소스 코드 차별화 플랫폼 MVC 구조 소개

Laravel5 빠른 인증 로직 프로세스 분석

위 내용은 PHP 작동 방식의 기본의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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