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

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

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼원래의
2019-08-22 13:43:472515검색

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으로 문의하세요.