PHP 프레임워크 ThinkPHP thinkphp에는 어떤 캐시 유형이 있나요?

thinkphp에는 어떤 캐시 유형이 있나요?

Aug 22, 2019 pm 01:43 PM
thinkphp 캐시 유형

thinkphp에는 어떤 캐시 유형이 있나요?

ThinkPHP는 데이터 캐싱, 정적 캐싱, 쿼리 캐싱 등 편리한 캐싱 방법을 제공합니다. 파일 모드, APC, 동적을 지원합니다. Db, Memcache, Shmop, Sqlite, Redis, Eaccelerator 및 Xcache를 포함한 데이터 캐시 유형과 사용자 정의 가능한 정적 캐시 규칙을 제공하고 액세스 작업을 위한 단축키 방법을 제공합니다.

데이터 캐시

Thinkphp 캐시 파일 구성

Home은 HomeConfconfig에서 제가 만든 프런트엔드 프로젝트입니다. . PHP는 캐시된 구성 파일을 찾고 구성은 다음과 같습니다:

<?php   
   return array(       
   &#39;DB_TYPE&#39;=>&#39;mysql&#39;,       
   &#39;DB_HOST&#39;=>&#39;127.0.0.1&#39;,       
  &#39;DB_NAME&#39;=>&#39;w3note&#39;,       
   &#39;DB_USER&#39;=>&#39;root&#39;,       
  &#39;DB_PWD&#39;=>&#39;123456&#39;,       
  &#39;DB_PORT&#39;=>&#39;3306&#39;,       
  &#39;DB_PREFIX&#39;=>&#39;w3_&#39;,       
  &#39;DATA_CACHE_TYPE&#39;=>&#39;file&#39;,//设置缓存方式为file       
  &#39;DATA_CACHE_TIME&#39;=>&#39;600&#39;,//缓存周期600秒       
 );       
 ?>
로그인 후 복사

Thinkphp 캐시 기능 사용

thinkphp에서는 캐시에 바로가기 캐시 기능 S()를 사용합니다. 사용법은 다음과 같습니다:

S(&#39;data&#39;,$Data);//使用data标识缓存$Data数据  
S(&#39;data&#39;,$Data,600);// 缓存$Data数据600秒  
 $Data = S(&#39;data&#39;);// 获取缓存数据  
S(&#39;data&#39;,NULL);// 删除缓存数据
로그인 후 복사

예제 데모

<?php       
 // 本类由系统自动生成,仅供测试用途       
  class IndexAction extends Action{       
    public function index(){       
        //如果有缓存,则读取缓存数据       
        //如果没有缓存,则读取数据库当中的数据放入缓存       
        $lists=S(&#39;lists&#39;);                     
        if(emptyempty($lists)){                           
          $news=M(&#39;news&#39;);   
          $lists=$news->select();   
          S(&#39;lists&#39;,$lists,600);   
          echo &#39;这是直接读取数据库的数据&#39;;       
           }   
        dump($list);  
 ?>
로그인 후 복사

Visit http://127.0.0.1/Home/index.php/Index/index,

첫 번째 방문:

데이터베이스에서 직접 데이터를 읽는 것입니다

array(10) {  
   [0] => array(12) {  
     ["id"] => string(1) "1"  
     ["catid"] => string(2) "13"  
     ["title"] => string(4) "thinkphp的缓存技术"  
     ["content"] => string(8) "thinkphp的缓存技术"  
     ["tags"] => string(4) "缓存"  
     ["thumb"] => string(0) ""  
     ["description"] => string(7) "thinkphp的缓存技术"  
     ["inputtime"] => string(10) "1348370202"  
     ["posid"] => string(1) "1"  
     ["ord"] => string(1) "2"  
     ["hits"] => string(1) "1"  
     ["status"] => string(1) "1"  
 }
로그인 후 복사
로그인 후 복사

두 번째 방문:

array(10) {  
   [0] => array(12) {  
     ["id"] => string(1) "1"  
     ["catid"] => string(2) "13"  
     ["title"] => string(4) "thinkphp的缓存技术"  
     ["content"] => string(8) "thinkphp的缓存技术"  
     ["tags"] => string(4) "缓存"  
     ["thumb"] => string(0) ""  
     ["description"] => string(7) "thinkphp的缓存技术"  
     ["inputtime"] => string(10) "1348370202"  
     ["posid"] => string(1) "1"  
     ["ord"] => string(1) "2"  
     ["hits"] => string(1) "1"  
     ["status"] => string(1) "1"  
 }
로그인 후 복사
로그인 후 복사

참고: 언제 처음 실행하면 위에 표시된 정보가 인쇄되고 페이지가 새로 고쳐집니다. "데이터베이스에서 직접 읽은 데이터입니다."가 누락되어 이전에 생성된 캐시된 데이터를 읽고 있음을 나타냅니다.

관련 권장 사항: "ThinkPHP 튜토리얼"

빠른 캐시

if 일부 간단한 데이터를 파일 형식으로 캐시하고 싶고 유효 기간에 대한 개념이 없는 경우 시스템에서는 더 빠른 작업을 위해 빠른 캐시 방법 F도 제공합니다.

데이터 데이터를 빠르게 캐시하고 기본적으로 DATA_PATH 디렉터리에 저장합니다.

F(&#39;data&#39;,$Data);
로그인 후 복사

데이터 데이터를 빠르게 캐시하고 지정된 디렉터리에 저장합니다.

F(&#39;data&#39;,$Data,TEMP_PATH);
로그인 후 복사

캐시된 데이터 가져오기

$Data = F(&#39;data&#39;);
로그인 후 복사

캐시된 데이터 삭제

F(&#39;data&#39;,NULL);
로그인 후 복사

F 메서드는 캐시 하위 디렉터리의 자동 생성을 지원하고 DATA_PATH 디렉터리 아래에 데이터 데이터를 캐시합니다. # 🎜🎜#

F(&#39;User/data&#39;,$Data);
로그인 후 복사

메소드 F는 버전 3.1.2부터 와일드카드 문자를 사용한 일괄 삭제 기능을 지원합니다. 다음을 사용하세요.

F(&#39;User/*&#39;,NULL);
로그인 후 복사

은 데이터 삭제를 의미합니다. DATA_PATH.'User/' 디렉터리 아래에 캐시가 있습니다.

시스템에 내장된 데이터 필드 정보 캐시는 빠른 캐싱 메커니즘을 사용합니다.

Query 캐시

높은 적시성을 요구하지 않는 데이터 쿼리의 경우 쿼리 캐시 기능을 사용하면 직접 사용하지 않고도 성능을 향상시킬 수 있습니다. . 캐시 메소드는 캐싱 및 검색을 수행합니다.

APP/config.php 구성:

&#39;DATA_CACHE_TIME&#39;   => 60, // 数据缓存有效期 0表示永久缓存
&#39;DATA_CACHE_TYPE&#39;   => &#39;File&#39;,
 // 数据缓存类型,支持:File|Db|Apc|Memcache|Shmop|Sqlite|Xcache|Apachenote|Eaccelerator
&#39;DB_SQL_BUILD_CACHE&#39; => true,
&#39;DB_SQL_BUILD_LENGTH&#39; => 20, // SQL缓存的队列长度
&#39;DATA_CACHE_PATH&#39; => TEMP_PATH,
로그인 후 복사

쿼리 캐시 기능은 모든 데이터베이스를 지원하며 모든 캐싱 방법 및 유효 기간을 지원합니다.

쿼리 캐시를 사용할 때 모델 클래스의 캐시 메서드만 호출하면 됩니다. 예:

$Model->cache(true)->select();
로그인 후 복사

캐시(true)를 사용하면 쿼리는 다음과 같이 됩니다. 현재 쿼리 SQL은 쿼리 캐시를 생성합니다. 기본적으로 캐시 방법은 DATA_CACHE_TYPE 매개변수에 의해 설정된 캐시 방법을 사용합니다(시스템 기본값은 파일 캐시가 사용됨을 의미함). DATA_CACHE_TIME 매개변수에 의해 설정되며, 쿼리 캐시의 캐시 방법 및 유효 기간도 별도로 지정할 수 있습니다.

$Model->cache(true,60,&#39;xcache&#39;)->select();
로그인 후 복사

은 현재 쿼리 캐시 캐시 방법이 xcache임을 나타내며 캐시 유효 기간은 60입니다. 초.

동일한 쿼리에서 캐시 메서드를 사용하지 않으면 이전에 Cache 메서드를 호출했더라도 캐시를 얻거나 생성하지 않습니다.

쿼리 캐시는 내부 호출에만 사용됩니다. 쿼리 캐시를 다른 프로그램에 공개하려면 다음과 같이 쿼리 캐시의 키를 지정할 수 있습니다.

$Model->cache(&#39;cache_name&#39;,60)->select();
로그인 후 복사
#🎜 🎜#외부적으로 S 메소드를 사용할 수 있습니다. 쿼리 캐시의 내용을 직접 얻을 수 있습니다.

$value = S(&#39;cache_name&#39;);
로그인 후 복사

쿼리 캐시는 select 메소드 외에도 find 및 getField 메소드와 파생 메소드도 지원합니다. 방법(통계 쿼리 및 동적 쿼리 방법 포함). 특정 애플리케이션의 경우 필요에 따라 캐싱 방법과 캐시 유효 기간을 선택할 수 있습니다.

SQL 구문 분석 캐시

ThinkPHP는 쿼리 캐싱 외에도 SQL 구문 분석 캐싱도 지원합니다. ThinkPHP의 ORM 메커니즘으로 인해 모든 SQL입니다. 동적으로 생성된 다음 데이터베이스 드라이버에 의해 실행됩니다.

따라서 애플리케이션에 SQL 쿼리 요구 사항이 많은 경우 SQL 구문 분석 캐시를 켜서 SQL 구문 분석을 줄이고 성능을 향상시킬 수 있습니다. SQL 구문 분석 캐싱을 활성화하려면

&#39;DB_SQL_BUILD_CACHE&#39; => true,
로그인 후 복사

을 설정하여 데이터베이스 쿼리에 대한 SQL 생성 캐시를 활성화하기만 하면 됩니다. 기본 캐싱 방법은 xcache 및 apc 캐싱만 지원할 수 있습니다. 설정 필요: # 🎜🎜#
&#39;DB_SQL_BUILD_QUEUE&#39; => &#39;xcache&#39;,
로그인 후 복사

우리는 프로젝트에 대한 SQL 쿼리의 양이 매우 클 수 있다는 것을 알고 있으므로 캐시 대기열 길이를 설정해야 합니다. 캐시는 20개 레코드를 초과하지 않으므로 다음과 같이 설정할 수 있습니다. # 🎜🎜#

&#39;DB_SQL_BUILD_LENGTH&#39; => 20, // SQL缓存的队列长度
로그인 후 복사

참고: 쿼리 방법만 SQL 구문 분석 캐시를 지원합니다

정적 캐시

#🎜🎜 #

정적 캐시 기능을 사용하려면 HTML_CACHE_ON 매개변수를 활성화하고 HTML_CACHE_RULES 구성 매개변수를 사용하여 정적 캐시 규칙 파일을 설정해야 합니다. 정적 캐싱 규칙은 애플리케이션 구성 파일에서도 정의할 수 있지만, 모듈 구성 파일에서 다양한 모듈에 대한 정적 캐싱 규칙을 정의하는 것이 좋습니다.

정적 규칙 정의

정적 규칙의 정의는 다음과 같습니다.

&#39;HTML_CACHE_ON&#39; => true, // 开启静态缓存
&#39;HTML_CACHE_TIME&#39; => 60, // 全局静态缓存有效期(秒)
&#39;HTML_FILE_SUFFIX&#39; => &#39;.shtml&#39;, // 设置静态缓存文件后缀
&#39;HTML_CACHE_RULES&#39; => array( // 定义静态缓存规则
 // 定义格式1 数组方式
 &#39;静态地址&#39; => array(&#39;静态规则&#39;, &#39;有效期&#39;, &#39;附加规则&#39;), 
 // 定义格式2 字符串方式
 &#39;静态地址&#39; => &#39;静态规则&#39;, 
)
로그인 후 복사
정의 형식 1은 편의를 위한 배열 정적 규칙에 대해 서로 다른 유효 기간을 개별적으로 설정합니다. 정의 형식 2는 문자열 모드를 사용하여 정적 규칙을 구독하고 HTML_CACHE_TIME에 의해 설정된 전역 정적 캐시 유효 기간을 사용합니다.

静态缓存文件的根目录在HTML_PATH定义的路径下面,并且只有定义了静态规则的操作才会进行静态缓存。 并且静态缓存支持不同的存储类型。 静态缓存仅在GET请求下面有效。

静态地址

静态地址包括下面几种定义格式:

第一种是定义全局的操作静态规则,例如定义所有的read操作的静态规则为:

&#39;read&#39;=>array(&#39;{id}&#39;,60)
로그인 후 복사

其中,{id}

表示取$_GET['id']

为静态缓存文件名,第二个参数表示缓存60秒。

第二种是定义全局的控制器静态规则,例如定义所有的User控制器的静态规则为:

&#39;user:&#39;=>array(&#39;User/{:action}_{id}&#39;,&#39;600&#39;)
로그인 후 복사

其中,{:action}

表示当前的操作名称

第三种是定义某个控制器的操作的静态规则,例如,我们需要定义Blog控制器的read操作进行静态缓存

&#39;blog:read&#39;=>array(&#39;{id}&#39;,0)
로그인 후 복사

第四种方式是定义全局的静态缓存规则,这个属于特殊情况下的使用,任何模块的操作都适用,例如:

&#39;*&#39;=>array(&#39;{$_SERVER.REQUEST_URI|md5}&#39;),
로그인 후 복사

表示根据当前的URL进行缓存。

静态规则

静态规则是用于定义要生成的静态文件的名称,静态规则的定义要确保不会冲突,写法可以包括以下情况:

1.使用系统变量

包括 _GET、_REQUEST、_SERVER、_SESSION、_COOKIE

格式:

{$_×××|function}
로그인 후 복사

例如:

{$_GET.name} 
{$_SERVER.REQUEST_URI|md5}
로그인 후 복사

2.使用框架特定的变量

{:module} 、{:controller} 和{:action}
로그인 후 복사

分别表示当前模块名、控制器名和操作名。

例如:

{:module}/{:controller}_{:action}
로그인 후 복사

3.使用_GET变量

{var|function}也就是说 {id}其实等效于 {$_GET.id}

4.直接使用函数

{|function} 例如:{|time}

5.支持混合定义

例如我们可以定义一个静态规则为:

&#39;{id},{name|md5}&#39;
로그인 후 복사

在{}之外的字符作为字符串对待,如果包含有"/",会自动创建目录。

例如,定义下面的静态规则:

{:module}/{:action}_{id}
로그인 후 복사

则会在静态目录下面创建模块名称的子目录,然后写入操作名_id.shtml 文件。

静态缓存有效期

单位为秒。如果不定义,则会获取配置参数HTML_CACHE_TIME的设置值,如果定义为0则表示永久缓存。

附加规则

通常用于对静态规则进行函数运算,例如:

&#39;read&#39;=>array(&#39;Think{id},{name}&#39;,&#39;60&#39;, &#39;md5&#39;)
로그인 후 복사

翻译后的静态规则是

md5(&#39;Think&#39;.$_GET[&#39;id&#39;]. &#39;, &#39;.$_GET[&#39;name&#39;]);
로그인 후 복사

위 내용은 thinkphp에는 어떤 캐시 유형이 있나요?의 상세 내용입니다. 자세한 내용은 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)

thinkphp 프로젝트를 실행하는 방법 thinkphp 프로젝트를 실행하는 방법 Apr 09, 2024 pm 05:33 PM

ThinkPHP 프로젝트를 실행하려면 다음이 필요합니다: Composer를 설치하고, 프로젝트 디렉터리를 입력하고 php bin/console을 실행하고, 시작 페이지를 보려면 http://localhost:8000을 방문하세요.

thinkphp에는 여러 버전이 있습니다. thinkphp에는 여러 버전이 있습니다. Apr 09, 2024 pm 06:09 PM

ThinkPHP에는 다양한 PHP 버전용으로 설계된 여러 버전이 있습니다. 메이저 버전에는 3.2, 5.0, 5.1, 6.0이 포함되며, 마이너 버전은 버그를 수정하고 새로운 기능을 제공하는 데 사용됩니다. 최신 안정 버전은 ThinkPHP 6.0.16입니다. 버전을 선택할 때 PHP 버전, 기능 요구 사항 및 커뮤니티 지원을 고려하십시오. 최상의 성능과 지원을 위해서는 최신 안정 버전을 사용하는 것이 좋습니다.

thinkphp를 실행하는 방법 thinkphp를 실행하는 방법 Apr 09, 2024 pm 05:39 PM

ThinkPHP Framework를 로컬에서 실행하는 단계: ThinkPHP Framework를 로컬 디렉터리에 다운로드하고 압축을 풉니다. ThinkPHP 루트 디렉터리를 가리키는 가상 호스트(선택 사항)를 만듭니다. 데이터베이스 연결 매개변수를 구성합니다. 웹 서버를 시작합니다. ThinkPHP 애플리케이션을 초기화합니다. ThinkPHP 애플리케이션 URL에 접속하여 실행하세요.

laravel과 thinkphp 중 어느 것이 더 낫나요? laravel과 thinkphp 중 어느 것이 더 낫나요? Apr 09, 2024 pm 03:18 PM

Laravel과 ThinkPHP 프레임워크의 성능 비교: ThinkPHP는 일반적으로 최적화 및 캐싱에 중점을 두고 Laravel보다 성능이 좋습니다. Laravel은 잘 작동하지만 복잡한 애플리케이션의 경우 ThinkPHP가 더 적합할 수 있습니다.

개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 Nov 22, 2023 pm 12:01 PM

"개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법" 인터넷 기술의 급속한 발전으로 인해 웹 응용 프로그램은 많은 수의 동시 요청과 복잡한 비즈니스 논리를 처리하기 위한 요구 사항이 점점 더 높아졌습니다. 시스템 성능과 사용자 경험을 향상시키기 위해 개발자는 이메일 보내기, 파일 업로드 처리, 보고서 생성 등과 같이 시간이 많이 걸리는 작업을 수행하기 위해 비동기 작업을 사용하는 것을 종종 고려합니다. PHP 분야에서 널리 사용되는 개발 프레임워크인 ThinkPHP 프레임워크는 비동기 작업을 구현하는 몇 가지 편리한 방법을 제공합니다.

thinkphp를 설치하는 방법 thinkphp를 설치하는 방법 Apr 09, 2024 pm 05:42 PM

ThinkPHP 설치 단계: PHP, Composer 및 MySQL 환경을 준비합니다. Composer를 사용하여 프로젝트를 만듭니다. ThinkPHP 프레임워크와 종속성을 설치합니다. 데이터베이스 연결을 구성합니다. 애플리케이션 코드를 생성합니다. 애플리케이션을 실행하고 http://localhost:8000을 방문하세요.

thinkphp 성능은 어떤가요? thinkphp 성능은 어떤가요? Apr 09, 2024 pm 05:24 PM

ThinkPHP는 캐싱 메커니즘, 코드 최적화, 병렬 처리 및 데이터베이스 최적화와 같은 장점을 갖춘 고성능 PHP 프레임워크입니다. 공식 성능 테스트에 따르면 초당 10,000개 이상의 요청을 처리할 수 있으며 JD.com, Ctrip과 같은 대규모 웹 사이트 및 엔터프라이즈 시스템에서 실제 응용 프로그램으로 널리 사용됩니다.

개발 제안: API 개발을 위해 ThinkPHP 프레임워크를 사용하는 방법 개발 제안: API 개발을 위해 ThinkPHP 프레임워크를 사용하는 방법 Nov 22, 2023 pm 05:18 PM

개발 제안: API 개발을 위해 ThinkPHP 프레임워크를 사용하는 방법 인터넷이 지속적으로 발전하면서 API(응용 프로그래밍 인터페이스)의 중요성이 점점 더 커지고 있습니다. API는 데이터 공유, 함수 호출 및 기타 작업을 실현할 수 있으며 개발자에게 비교적 간단하고 빠른 개발 방법을 제공합니다. 뛰어난 PHP 개발 프레임워크인 ThinkPHP 프레임워크는 효율적이고 확장 가능하며 사용하기 쉽습니다.

See all articles