>백엔드 개발 >PHP 문제 >PHP에서 높은 동시성을 해결하는 방법

PHP에서 높은 동시성을 해결하는 방법

王林
王林원래의
2019-09-21 17:57:5620865검색

PHP에서 높은 동시성을 해결하는 방법

PHP의 높은 동시성 해결 방법

1. 애플리케이션과 정적 리소스 분리

정적 리소스(js, css, 그림 등)를 전용 서버에 넣습니다.

2. 페이지 캐싱

애플리케이션에서 생성된 페이지를 캐시하여 많은 CPU 리소스를 절약하세요. 데이터가 자주 변경되는 일부 페이지의 경우 ajax를 사용하여 처리할 수 있습니다.

동영상 강좌 추천 →: "수백만 개의 데이터 동시성 솔루션(이론 + 실무)"

3. 클러스터링 및 배포

클러스터, 여러 서버가 동일한 기능을 가지며 주로 전환으로 작동합니다. . 분산되어 여러 서버에 여러 비즈니스를 배치하여 요청을 처리하는 데 여러 서버가 필요할 수 있으므로 요청 처리 속도가 향상됩니다. 정적 자원 클러스터와 애플리케이션 클러스터로 구분됩니다. 후자는 더 복잡하며 세션 동기화와 같은 문제를 고려해야 하는 경우가 많습니다.

4. 역방향 프록시

클라이언트가 직접 접속하는 서버는 서비스를 직접 제공하는 서버가 아니며, 다른 서버에서 리소스를 얻어서 사용자에게 결과를 반환합니다.

프록시 서버 및 역방향 프록시 서버:

프록시 서버는 우리를 대신하여 리소스에 액세스한 다음 결과를 반환합니다. 예를 들어 외부 네트워크의 프록시 서버에 액세스합니다. 역방향 프록시 서버는 우리가 일반적으로 서버에 액세스할 때 서버 자체가 다른 서버를 호출하는 서버입니다.

우리는 서비스를 제공하기 위해 프록시 서버를 적극적으로 사용하며 자체 도메인 이름이 필요하지 않습니다. 역방향 프록시는 서버 자체에서 사용되며 자체 도메인 이름이 있다는 것을 모릅니다.

5. CDN

CDN은 일반적인 클러스터의 여러 페이지 캐시 서버와 비교할 때 저장 위치와 할당 요청 방법이 다르다는 점입니다.

CDN 서버는 전국에 분산되어 있으며 요청을 받은 후 가장 적합한 CDN 서버 노드에 할당되어 데이터를 얻습니다. 각 CDN 노드는 페이지 캐싱 서버입니다.

배포 방법:

은 일반적인 로드 밸런싱이 아니라 도메인 이름을 확인할 때 할당하는 전용 CDN 도메인 이름 확인 서버입니다.

일반적인 접근 방식은 ISP가 CNAME을 사용하여 도메인 이름을 특정 도메인 이름으로 확인한 다음 전용 CDN 서버를 사용하여 확인된 도메인 이름을 해당 CDN으로 확인(브라우저로 돌아온 후 액세스)하는 것입니다. 마디. 각 노드는 여러 서버로 클러스터링될 수도 있습니다.

높은 동시성을 처리하기 위한 비즈니스 로직은 다음과 같습니다.

프런트엔드: 비동기 요청 + 리소스 정적화 + CDN

백엔드: 요청 대기열 + 폴링 배포 + 로드 밸런싱 + 공유 캐시

데이터 레이어: redis 캐시 + 데이터 테이블 + 쓰기 대기열

저장소: raid 배열 + 핫 대기

네트워크: DNS 폴링 + DDOS 공격 보호

추천 튜토리얼: PHP 비디오 튜토리얼

위 내용은 PHP에서 높은 동시성을 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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