>  기사  >  백엔드 개발  >  ThinkPHP의 정적 캐싱과 동적 캐싱 구현 분석

ThinkPHP의 정적 캐싱과 동적 캐싱 구현 분석

不言
不言원래의
2018-06-08 14:53:061496검색

이 글에서는 주로 정적 캐싱과 동적 캐싱을 구현하는 ThinkPHP의 예제 코드를 소개합니다. 관심 있는 친구들은 참고해 보세요.

정적 캐싱

정적 캐싱 기능을 사용하려면 활성화해야 합니다. HTML_CACHE_ON 매개변수를 사용하고 HTML_CACHE_RULES 구성 매개변수를 사용하여 정적 캐시 규칙 파일을 설정합니다.

정적 규칙 정의

'HTML_CACHE_ON'   =>  true, // 开启静态缓存
'HTML_CACHE_TIME'  =>  60,  // 全局静态缓存有效期(秒)
'HTML_FILE_SUFFIX' =>  '.shtml', // 设置静态缓存文件后缀
'HTML_CACHE_RULES' =>   array( // 定义静态缓存规则
   // 定义格式1 数组方式
   '静态地址'  =>   array('静态规则', '有效期', '附加规则'), 
   // 定义格式2 字符串方式
   '静态地址'  =>   '静态规则', 
)

정적 캐시 파일의 루트 디렉터리는 HTML_PATH에 정의된 경로 아래에 있으며, 정의된 정적 규칙이 있는 작업만 정적으로 캐시됩니다. 그리고 정적 캐시는 다양한 스토리지 유형을 지원합니다. 정적 캐싱은 GET 요청에서만 작동합니다.

정적 주소

전역 작업 정적 규칙

'read'=>array('{id}',60)//定义所有的read操作的静态规则

전역 컨트롤러 정적 규칙 정의

'user:'=>array('User/{:action}_{id}','600')//定义所有的User控制器的静态规则

특정 컨트롤러 작업에 대한 정적 규칙 정의 //정적 캐싱을 위한 블로그 컨트롤러의 읽기 작업 정의

'blog:read'=>array('{id}',0)//参数为0表示永久缓存

전역 정적 캐싱 규칙 정의

'*'=>array('{$_SERVER.REQUEST_URI|md5}')//这个属于特殊情况下的使用,任何模块的操作都适用

정적 규칙

정적 규칙은 생성할 정적 파일의 이름을 정의하는 데 사용됩니다. 정적 규칙 정의는 충돌이 없음을 보장해야 합니다.

시스템 변수 사용

{$_×××|function}//_GET、_REQUEST、_SERVER、_SESSION、_COOKIE
{$_GET.name} 
{$_SERVER.REQUEST_URI|md5}

프레임워크 맞춤형 변수 사용

{:module}/{:controller}_{:action}//{:module} 、{:controller} 和{:action}分别表示当前模块名、控制器名和操作名。

_GET 변수 사용

{var|function}//{id}其实等效于 {$_GET.id}

함수 직접 사용

{|function}//{|time},time函数获取时间后作为文件名称

혼합 정의

'{id},{name|md5}' //在{}之外的字符作为字符串对待,如果包含有"/",会自动创建目录。
{:module}/{:action}_{id}//会在静态目录下面创建模块名称的子目录,然后写入操作名_id.shtml 文件。

동적 캐시

[S 메서드 데이터 캐시]

캐시 초기화

S(array('type'=>'xcache','expire'=>60));

현재 시스템에서 지원되는 캐시 유형에는 Apachenote, Apc, Db, Eaccelerator, File, Memcache, Redis, Shmop, Sqlite, Wincache 및 Xcache가 있습니다. S 메소드가 초기화를 위한 타입 파라미터를 전달하지 않으면 구성 파일에 설정된 DATA_CACHE_TYPE 파라미터 값을 기본 타입으로 읽어온다. 마찬가지로 prefix 매개변수를 전달하지 않으면 구성 파일의 DATA_CACHE_PREFIX 매개변수 값을 읽습니다. 만료 매개변수를 전달하지 않으면 DATA_CACHE_TIME 구성 값을 기본값으로 읽습니다.

글로벌 캐싱 방법의 경우 일반적으로 혼동을 피하기 위해 다양한 애플리케이션을 구별하기 위해 접두사(캐시 접두사) 매개 변수를 추가하는 것이 좋습니다.

캐시 설정

데이터 캐시는 캐시 대기열을 지원할 수 있습니다. 간단히 말해서, 초기화 중에 길이 매개변수만 지정하면 됩니다.

S('name',$value);
S('name',$value,300);//缓存数据300秒
S('name',$value,array('type'=>'file','expire'=>300));//改变之前的缓存方式或者更多的参数
S(array('type'=>'xcache','length'=>100,'expire'=>60));//系统只会缓存最近的100条缓存数据。

캐시 ​​읽기

$value = S('name');//如果缓存标识不存在或者已经过期,则返回false,否则返回缓存值。

캐시 ​​삭제

S('name',null);

참고: 각 캐시를 사용할 때 ThinkPHP는 해당 드라이버 파일을 로드하고 해당 구성을 설정해야 합니다.

사용 예

$user = M('User');
$value = S('list');
if (empty($value)) {
  $list = $user->select();
  S('list', $list, 3600);
  echo '这个是直接从数据库中读取的文件';
  dump($list);
} else {
  echo '这个是缓存文件';
  dump($value);
}

[빠른 캐시]

시스템은 또한 더 빠른 작업에 사용할 수 있는 빠른 캐시 방법 F를 제공합니다. 그러나 F 방법에는 유효 기간이 없으며 F 방법은 다양한 저장 유형을 지원할 수 있습니다. .If 파일 형식은 기본적으로 DATA_PATH 디렉터리에 저장됩니다.

빠른 데이터 캐시

F('data',$Data);
F('data',$Data,TEMP_PATH);//快速缓存Data数据,保存到指定的目录
F('User/data',$Data);//F方法支持自动创建缓存子目录,在DATA_PATH目录下面缓存data数据,如果User子目录不存在,则自动创建。

캐시된 데이터 가져오기

$Data = F('data');

캐시된 데이터 삭제

F('data',NULL);

[쿼리 캐시]

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

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

$Model->cache(true)->where('status=1')->select();

cache(true)를 사용하면 현재 쿼리 조건과 쿼리 중 기타 정보를 기반으로 고유 식별자가 있는 쿼리 캐시가 생성됩니다. 키를 지정하면 key라는 이름의 쿼리 캐시가 직접 생성됩니다.

$Model->cache('cache_name')->select();

기본적으로 캐시 방식은 DATA_CACHE_TYPE 매개변수에 설정된 캐시 방식을 사용합니다. (시스템 기본값은 파일 캐시를 사용함을 의미합니다.) 캐시 유효 기간은 DATA_CACHE_TIME 매개변수에 설정된 시간입니다. 쿼리 캐시의 유효 기간도 별도로 지정할 수 있습니다.

$Model->cache(true,60,'xcache')->select();

쿼리 캐시의 키를 지정하면 S 메소드를 통해 쿼리 캐시의 내용을 외부에서 직접 얻을 수 있습니다.

$value = S('cache_name');

select 메소드 외에도 쿼리 캐시는 find 및 getField 메소드와 파생 메소드(통계 쿼리 및 동적 쿼리 메소드 포함)도 지원합니다.

$Model->where($map)->cache('key',60)->find();

이 기사는 주로 공식 문서에서 발췌되었습니다. 궁금한 사항이 있는 경우 ThinkPHP3.2 공식 문서 - 캐시를 참조하세요.

위는 이 기사의 전체 내용입니다. 더 많은 관련 내용을 보시려면 PHP 중국어 웹사이트를 주목해주세요!

관련 권장사항:

ThinkPHP는 원클릭 캐시 삭제 방법을 실현합니다

PHP에서 캐시를 삭제하는 여러 방법 요약

위 내용은 ThinkPHP의 정적 캐싱과 동적 캐싱 구현 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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