백엔드 개발 PHP 튜토리얼 PHP9 대용량 캐시 기술

PHP9 대용량 캐시 기술

Apr 04, 2017 pm 03:22 PM
캐싱 기술

1. 전체 페이지정적캐시

즉, 모든 페이지가 html 정적 페이지로 생성됩니다. 사용자 방문 PHP 서버 구문 분석 과정을 거치지 않고 정적 페이지에 직접 액세스합니다. 이 방법은 dedecs와 같은 CMS 시스템에서 더 일반적입니다.

일반적인 구현 방법은 출력 캐싱을 사용하는 것입니다.

Ob_start()*** *** 실행할 코드*********$content = Ob_get_contents();****캐시된 콘텐츠를 html 파일에 쓰기*****Ob_end_clean ();

2.페이지 부분 캐싱

페이지에서 자주 변경되지 않는 부분은 정적으로 캐시하고, 자주 변경되는 블록은 캐시하지 않고 최종적으로 함께 표시하는 방법입니다. ; ob_get_contents와 유사한 방법을 사용하여 구현하거나 ESI와 같은 페이지 조각 캐싱 전략을 사용하여 동적 페이지에서 상대적으로 정적인 조각을 캐시할 수 있습니다(ESI 기술, Baidu 참조, 여기에 자세히 설명되지 않음).

이 방법은 예를 들어 쇼핑몰의 제품 페이지에서 사용할 수 있습니다.

3. 데이터 캐싱

이름에서 알 수 있듯이 캐싱하는 방법입니다. data ;예를 들어, 상품 ID를 이용해 쇼핑몰의 특정 상품 정보를 요청하면 매장 정보, 상품 정보, 기타 데이터를 포함한 데이터를 php 파일로 캐시할 수 있습니다. , 그리고 파일 이름에는 고유 식별자를 생성하기 위한 제품 ID가 포함되어 있습니다. 다음에 누군가가 이 제품을 보려고 할 때 쿼리하기 위해 데이터베이스 로 이동할 필요 없이 이 파일의 정보가 먼저 직접 조정됩니다. > 실제로 캐시된 파일은 php 배열 등입니다.

Ecmall이 방법은

4. 쿼리 캐시

사실 이는 쿼리문에 따라 얻은 데이터를 파일에 캐시하는 데이터 캐싱과 같은 개념입니다. 다음 번에 데이터베이스를 다시 확인하지 않고 이 파일에서 데이터를 직접 검색합니다. 그러나 여기의 캐시 파일 이름은 고유 식별자를 설정하기 위해 쿼리 문을 기반으로 해야 할 수도 있습니다. 시간 변경

사실 이는 실제 캐싱 방법이 아닙니다. 위의 캐싱 기술 2, 3, 4는 일반적으로 시간 변경 판단을 사용합니다. 즉, 캐시된 파일에 유효한 시간을 설정해야 합니다. 이 유효한 시간에 동일한 액세스는 먼저 캐시된 파일의 콘텐츠를 가져오지만 캐시가 설정된 캐시 시간을 초과하면 데이터베이스에서 데이터를 다시 가져와 최신 캐시 파일을 생성해야 합니다. 저희 쇼핑몰 홈페이지는

2시간에 한 번씩 업데이트됩니다. 즉, 데이터베이스 내용이 수정되면 캐시 파일이 즉시 업데이트됩니다.

예를 들어, 사람이 많이 방문하고 상품이 많은 쇼핑몰에서는 상품 테이블이 상대적으로 커야 합니다. 이 테이블에 대한 부담도 큽니다. 판매자가 백그라운드에서 제품 정보를 수정할 때 저장을 클릭하면 동시에 캐시 파일이 업데이트됩니다. 그러면 구매자가 이 제품 정보에 액세스하면 실제로 데이터베이스에 액세스할 필요 없이 정적 페이지에 액세스하게 됩니다.

캐싱이 없는 제품 페이지를 상상해 보세요. 제품에 액세스할 때마다 데이터베이스를 확인해야 합니다. .100,000명이 온라인으로 상품을 검색한다면 서버는 엄청난 압박을 받게 될 것입니다.

6. 인메모리 캐싱

이때 가장 먼저 떠오르는 것은

Memcached

; memcached는 고성능 분산 메모리 캐시 서버입니다. 일반적인 사용 목적은 데이터베이스 쿼리 결과를 캐싱하여 동적 웹 애플리케이션의 속도와 확장성을 높여 데이터베이스 액세스 횟수를 줄이는 것입니다.

캐시해야 하는 정보를 시스템 메모리에 캐시합니다. 정보를 가져와야 할 때 더 일반적으로 사용되는 방법은

입니다. –>값 방법;

$memcachehost = '192.168.6.191';

$memcacheport = 11211;$memcachel

if

e = 60;

$memcache = new Memcache;

$memcache->connect($memcachehost,$memcacheport) 또는 사망("연결할 수 없음") ;

$memcache->

set('키','캐시된 콘텐츠');

$get = $memcache->get($key); //정보를 얻으시겠습니까?> ;

7.아파치 캐시 모듈

apache 설치 후에는 캐시가 허용되지 않습니다. 외부 캐시나 오징어 서버에 웹 가속이 필요한 경우에는 httpd.conf에 설정해야 합니다. 물론 Apache 설치 시 mod_cache 모듈을 활성화해야 한다는 전제가 있습니다.

아파치 설치 시: ./configure –enable-cache –enable-disk-cache –enable-mem-cache

8, php APC캐시 확장

Php에는 Windows의 경우 php_apc.dll인 APC 캐시 확장이 있습니다. 먼저 이 모듈을 로드한 다음 php.ini에서 구성해야 합니다.

[apc ]

extension=php_apc.dll

apc.rfc1867 = on

upload_max_filesize = 100M

post_max_size = 100M

apc.max_file_size = 200M

upload_max_filesize = 1000M

post_max_size = 1000M

max_execution_time = 600; 실행 값(초), 기본값은 30초

max_input_time = 600; 각 PHP 페이지가 데이터를 수신하는 데 필요한 최대 시간, 기본값은 60

memory_limit = 128M입니다. 메모리, 기본 8M

9. Opcode 캐시

PHP의 실행 프로세스는 다음 그림과 같습니다.

PHP9 대용량 캐시 기술


먼저 php 코드를 토큰으로 파싱한 다음 Opcode 코드로 컴파일하고 마지막으로 Opcode 코드를 실행하여 결과를 반환합니다. 동일한 php 파일에서 Opcode 코드는 한 번 실행 시 캐시될 수 있습니다. 다음에 이 페이지를 실행하면 캐시된 Opcode 코드를 직접 찾아 중간 단계 없이 마지막 단계를 직접 실행하게 됩니다.

더 잘 알려진 것으로는 XCache, Turck MM Cache, PHP Accelerator 등이 있습니다.

위 내용은 PHP9 대용량 캐시 기술의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Java 캐싱 기술의 TTL 및 TTI Java 캐싱 기술의 TTL 및 TTI Jun 20, 2023 am 10:58 AM

Java 캐싱 기술의 TTL 및 TTI는 모든 소프트웨어 시스템의 캐싱 기술과 분리될 수 없습니다. 일반적인 캐싱 기술인 Java 캐시는 메모리 기반, 디스크 기반 또는 클러스터 기반 캐싱과 같은 다양한 캐싱 전략에 따라 여러 유형으로 나눌 수 있습니다. 유형에 관계없이 캐시는 더 복잡해지고 더 널리 사용되는 경우가 많습니다. 그러나 캐시 만료 시간, 즉 TTL 및 TTI와 같은 캐싱 기술을 사용할 때 주의해야 할 몇 가지 문제도 있습니다. TTL 및 T

Redisson 캐싱 기술에 대해 알아보기 Redisson 캐싱 기술에 대해 알아보기 Jun 21, 2023 am 09:54 AM

Redisson은 Java 애플리케이션을 위한 Redis 기반 캐싱 솔루션입니다. 이는 Java 애플리케이션에서 Redis를 캐시로 보다 편리하고 효율적으로 사용할 수 있도록 하는 많은 유용한 기능을 제공합니다. Redisson이 제공하는 캐싱 기능은 다음과 같습니다. 1. 분산 매핑(Map): Redisson은 분산 맵을 생성하기 위한 몇 가지 API를 제공합니다. 이러한 맵에는 키-값 쌍, 해시 항목 또는 개체가 포함될 수 있으며 여러 노드 간의 공유를 지원할 수 있습니다.

APCu 캐싱 기술을 사용하여 PHP 애플리케이션의 성능을 최적화하는 방법은 무엇입니까? APCu 캐싱 기술을 사용하여 PHP 애플리케이션의 성능을 최적화하는 방법은 무엇입니까? Jun 20, 2023 pm 09:47 PM

현재 PHP는 인터넷 개발에서 가장 인기 있는 프로그래밍 언어 중 하나가 되었으며, PHP 프로그램의 성능 최적화도 가장 시급한 문제 중 하나가 되었습니다. 대규모 동시 요청을 처리할 때 1초의 지연은 사용자 경험에 큰 영향을 미칠 수 있습니다. 오늘날 APCu(AlternativePHPCache) 캐싱 기술은 PHP 애플리케이션 성능을 최적화하는 중요한 방법 중 하나가 되었습니다. 이 기사에서는 APCu 캐싱 기술을 사용하여 PHP 애플리케이션의 성능을 최적화하는 방법을 소개합니다. 1. APC

Aerospike 캐싱 기술에 대해 알아보기 Aerospike 캐싱 기술에 대해 알아보기 Jun 20, 2023 am 11:28 AM

디지털 시대가 도래하면서 빅데이터는 사회 각계각층에서 없어서는 안 될 필수 요소가 되었습니다. 대용량 데이터 처리를 위한 솔루션으로 캐싱 기술의 중요성이 점점 부각되고 있습니다. Aerospike는 고성능 캐싱 기술입니다. 이 기사에서는 Aerospike 캐싱 기술의 원리, 특성 및 응용 시나리오에 대해 자세히 알아봅니다. 1. Aerospike 캐싱 기술의 원리 Aerospike는 메모리와 플래시 메모리 기반의 Key-Value 데이터베이스를 사용합니다.

인피니스팬 서버 캐싱 기술 알아보기 인피니스팬 서버 캐싱 기술 알아보기 Jun 20, 2023 pm 08:01 PM

Infinispan은 대용량 캐시 데이터를 처리하는 데 사용할 수 있는 고도로 동시 분산 캐시 시스템입니다. InfinispanServer는 Infinispan 캐시 기술의 배포 형태로 하나 이상의 노드에 Infinispan 캐시를 배포하여 더 나은 캐시 활용도를 얻을 수 있습니다. 사용 중인 InfinispanServer의 장점은 주로 다음과 같은 측면을 포함합니다. 확장성이 뛰어난 InfinispanServer

Memcached 캐싱 기술을 사용하여 PHP 애플리케이션 CPU 사용량을 최적화하는 방법은 무엇입니까? Memcached 캐싱 기술을 사용하여 PHP 애플리케이션 CPU 사용량을 최적화하는 방법은 무엇입니까? Jun 21, 2023 pm 05:07 PM

인터넷이 발전하면서 PHP 애플리케이션은 인터넷 애플리케이션 분야에서 점점 더 보편화되었습니다. 그러나 PHP 애플리케이션의 동시 액세스가 높으면 서버의 CPU 사용량이 높아져 애플리케이션 성능에 영향을 줄 수 있습니다. PHP 애플리케이션의 성능을 최적화하기 위해서는 Memcached 캐싱 기술이 좋은 선택이 되었습니다. 이 기사에서는 Memcached 캐싱 기술을 사용하여 PHP 애플리케이션의 CPU 사용량을 최적화하는 방법을 소개합니다. Memcached 캐싱 기술 소개 Memcached는

Golang의 캐싱 기술과 5G 애플리케이션의 통합 혁신. Golang의 캐싱 기술과 5G 애플리케이션의 통합 혁신. Jun 20, 2023 pm 08:43 PM

5G 기술이 점차 대중화됨에 따라 점점 더 많은 애플리케이션 시나리오에서 효율적인 네트워크 전송과 데이터 응답 속도가 필요합니다. 캐싱 기술은 일반적인 성능 최적화 방법으로 데이터 응답 속도를 향상시키는 데 중요한 역할을 합니다. 이 기사에서는 Golang의 캐싱 기술과 5G 애플리케이션의 통합 혁신을 살펴보고 둘 사이의 관계를 살펴보겠습니다. 먼저 5G 애플리케이션이 무엇인지 이해해야 합니다. 5G 애플리케이션은 5G 네트워크 아키텍처와 기술을 기반으로 하는 애플리케이션을 말하며, 고속, 저지연, 높은 신뢰성이 특징입니다.

Java 캐싱 기술의 분산 캐싱에 대한 심층 분석 Java 캐싱 기술의 분산 캐싱에 대한 심층 분석 Jun 21, 2023 am 09:00 AM

동시성이 높고 빅데이터가 많은 현재 인터넷 환경에서 캐싱 기술은 시스템 성능을 향상시키는 중요한 수단 중 하나가 되었습니다. Java 캐싱 기술에 있어서 분산 캐싱은 매우 중요한 기술입니다. 그렇다면 분산 캐시란 무엇일까요? 이 기사에서는 Java 캐싱 기술의 분산 캐싱에 대해 자세히 설명합니다. 1. 분산 캐시의 기본 개념 분산 캐시는 캐시 데이터를 여러 노드에 저장하는 캐시 시스템을 의미합니다. 그 중 각 노드에는 캐시된 데이터의 전체 복사본이 포함되어 있으며 노드 중 하나에 장애가 발생하면 서로 백업할 수 있습니다.

See all articles