>  기사  >  백엔드 개발  >  PHP-yii 프레임워크 캐싱 지식 수집

PHP-yii 프레임워크 캐싱 지식 수집

小云云
小云云원래의
2017-11-16 11:18:161269검색

Yii는 고성능 PHP5 웹 애플리케이션 개발 프레임워크입니다. 간단한 명령줄 도구인 yiic은 웹 애플리케이션 코드 프레임워크를 신속하게 생성할 수 있습니다. 개발자는 생성된 코드 프레임워크를 기반으로 비즈니스 로직을 추가하여 애플리케이션 개발을 신속하게 완료할 수 있습니다. 캐싱은 웹 사이트 성능을 향상시키는 간단하고 효과적인 방법입니다. 약간 더 큰 크기의 웹 사이트는 필요할 때 상대적으로 정적인 데이터를 캐시에 저장하므로 데이터베이스에서 데이터를 쿼리하고 생성하는 시간을 절약하고 데이터베이스에 대한 부담을 줄여 웹 사이트의 성능을 향상시킬 수 있습니다. 강력한 PHP 오픈 소스 프레임워크인 Yii는 다양한 인기 캐시에 대한 인터페이스를 제공하며 실제 필요에 따라 다양한 캐시를 사용할 수 있습니다.

yii의 캐시 관련 구성 요소는 yii/framework/caching 디렉터리에 저장되어 있습니다. 이 디렉터리를 보면 yii가 어떤 캐시를 지원하는지 알 수 있습니다. 아래에서는 관련 파일에 대해 간략하게 소개합니다.

CMemCache: PHP memcache 확장을 사용합니다.

CApcCache: PHP APC 확장을 사용합니다.

CXCache: PHP XCache 확장을 사용합니다. 이는 버전 1.0.1부터 지원됩니다.

CEAcceleratorCache: PHP EAccelerator 확장을 사용합니다.

CDbCache: 데이터 테이블을 사용하여 캐시 데이터를 저장합니다. 기본적으로 런타임 디렉터리에 SQLite3 데이터베이스를 생성하고 사용합니다. ConnectionID 속성을 설정하여 사용할 데이터베이스를 지정할 수도 있습니다.

CZendDataCache: Zend 데이터 캐시를 백엔드 캐싱 매체로 사용합니다. 이는 버전 1.0.4부터 지원됩니다.

CFileCache: 파일을 사용하여 캐시 데이터를 저장합니다. 이는 대량의 데이터(예: 페이지)를 저장하는 데 특히 유용합니다. 이는 버전 1.0.6부터 지원됩니다.

CDummyCache: 현재 더미 캐시는 캐싱 기능을 구현하지 않습니다. 이 구성 요소의 목적은 캐시 가용성을 확인해야 하는 코드를 단순화하는 것입니다. 예를 들어 개발 단계에서 또는 서버가 아직 실제 캐싱 기능을 지원하지 않는 경우 이 캐싱 구성 요소를 사용할 수 있습니다. 실제 캐싱 지원이 활성화되면 해당 캐싱 구성 요소를 사용하도록 전환할 수 있습니다. 두 경우 모두 Yii::app()->cache가 null일 수 있다는 걱정 없이 동일한 코드 Yii::app()->cache->get($key)를 사용하여 데이터 조각을 가져올 수 있습니다. 이 구성 요소는 버전 1.0.5부터 지원됩니다.

팁: 이러한 모든 캐싱 구성 요소는 동일한 기본 클래스 CCache에서 상속되므로 캐시를 사용하는 코드를 변경하지 않고도 다른 캐싱 방법으로 전환할 수 있습니다.

Yii에서 캐시를 사용하는 것은 주로 캐시 구성 요소를 구성하고 액세스하는 것을 포함합니다. 다음은 Memcache 캐시 구성 요소와 파일 캐시 구성 요소를 예시로 사용한 두 가지 설명입니다.

(1) Memcache 캐시 예시:

다음 애플리케이션 구성은 두 개의 캐시 서버를 사용하는 Memcache 캐시 구성 요소를 지정합니다.

array(
......
'components'=>array(
......
'phpernote_cache'=>array(
'class'=>'system.caching.CMemCache',
'servers'=>array(
array('host'=>'10.201.1.101', 'port'=>11211, 'weight'=>60),
array('host'=>'10.201.1.102', 'port'=>11211, 'weight'=>40),
),
),
),
);

프로그램이 실행될 때 실행 중인 경우 컨트롤러 메서드에서 Yii::app()->phpernote_cache를 통해 캐시 구성 요소에 액세스할 수 있습니다. 예:

Yii::app ()->phpernote_cache->set($key,$value ,$expire);

Yii::app()->phpernote_cache->add($id,$value)

Yii::app ()->phpernote_cache->get($key);

(2) 파일 캐싱 예:

1. 구성 파일에 캐시 구성 정보를 추가합니다.

array(
......
'components'=>array(
......
'cache'=>array(
'class'=>'system.caching.CFileCache',
'directoryLevel'=>2
),
),
),
);

위 구성에서 디렉토리 수준은 캐시된 페이지가 너무 많은 경우 캐시된 파일의 디렉터리 깊이를 설정합니다. 더 크게 설정하십시오. 그렇지 않으면 각 디렉토리에 많은 페이지가 있게 됩니다.

2. 캐시할 컨트롤러에서 필터를 정의합니다.

public function filters(){
return array(
array(
'COutputCache + post, list',
'duration'=>3600,
'varyByParam'=>array('id','page'),
'dependency'=>array(
'class'=>'CDbCacheDependency',
'sql'=>'SELECT MAX(id) FROM phpernote_article',
)
);
}

COutputCache는 캐싱을 처리하는 데 사용되는 클래스입니다. 'COutputCache'만 입력하면 컨트롤러의 모든 작업이 캐시를 통해 필터링됩니다. 즉, 다음 메서드만 수행됩니다. 캐시됨: actionPost, actionList .

duration은 초 단위의 캐시 시간이고,

varyByParam은 GET 매개변수 이름 목록을 지정하고 해당 값을 사용하여 캐시된 콘텐츠의 버전을 결정합니다. 즉, 동일한 작업을 사용하여 서로 다른 매개변수를 구별합니다. 페이지. 이것은 ID와 페이지를 사용하여 서로 다른 페이지를 구분합니다.

variableByParam 외에도 다른 조건을 사용하여 페이지를 구분할 수 있습니다.

varyByExpression: 사용자 정의 PHP 표현식의 결과에 따라 변경할 캐시 콘텐츠를 지정합니다.

varyByRoute: 경로에 따라 변경할 캐시 콘텐츠를 지정합니다. 요청(컨트롤러 및 작업)

varyBySession: 콘텐츠를 캐시할지 여부를 지정합니다.

dependent'는 캐시 무효화 종속성을 지정합니다. 이 예에서는 데이터베이스 종속성을 지정합니다. 데이터 테이블의 특정 값을 통해 캐시가 만료되었는지 확인합니다. 예를 들어, 테이블에 새 레코드가 추가되면 캐시가 5분(
팁: Yii는 Redis도 지원할 수 있으므로 플러그인을 설치해야 합니다: http://www.yiibase.com/download/view/32.html

缓存可以在不同的级别使用。在最低级别,可用来缓存单个数据(数据缓存)。往上一级,我们缓存一个由视图脚本生成的页面片断(片段缓存)。在最高级别,可存储整个页面以便需要的时候直接从缓存读取。本文说明页面缓存的配置及实现效果;

数据缓存

数据缓存即存储一些 PHP 变量到缓存中,以后再从缓存中取出来。出于此目的,缓存组件的基类 CCache 提供了两个最常用的方法: set() 和 get()。

要在缓存中存储一个变量 $value ,我们选择一个唯一 ID 并调用 set() 存储它:

Yii::app()->cache->set($id, $value);缓存的数据将一直留在缓存中,除非它由于某些缓存策略(例如缓存空间已满,旧的数据被删除)而被清除。 要改变这种行为,我们可以在调用 set() 的同时提供一个过期参数,这样在设定的时间段之后,缓存数据将被清除:

// 值$value 在缓存中最多保留30秒
Yii::app()->cache->set($id, $value, 30);稍后当我们需要访问此变量时(在同一个或不同的 Web 请求中),就可以通过 ID 调用 get() 从缓存中将其取回。 如果返回的是 false,表示此值在缓存中不可用,我们应该重新生成它。

$value=Yii::app()->cache->get($id);
if($value===false){
    // 因为在缓存中没找到 $value ,重新生成它 ,
    // 并将它存入缓存以备以后使用:
    // Yii::app()->cache->set($id,$value);
}

为要存入缓存的变量选择 ID 时,要确保此 ID 对应用中所有其他存入缓存的变量是唯一的。而在不同的应用之间,这个 ID 不需要是唯一的。缓存组件具有足够的智慧区分不同应用中的 ID。

一些缓存存储器,例如 MemCache, APC, 支持以批量模式获取多个缓存值。这可以减少获取缓存数据时带来的开销。从版本 1.0.8 起,Yii 提供了一个新的名为 mget() 的方法。它可以利用此功能。如果底层缓存存储器不支持此功能,mget() 依然可以模拟实现它。

要从缓存中清除一个缓存值,调用 delete(); 要清楚缓存中的所有数据,调用 flush()。 当调用 flush() 时一定要小心,因为它会同时清除其他应用中的缓存。

提示: 由于 CCache 实现了 ArrayAccess,因此缓存组件也可以像一个数组一样使用。下面是几个例子:

$cache=Yii::app()->cache;
$cache['username']=$value1;  // 相当于: $cache->set('username',$value1);
$value2=$cache['username'];  // 相当于: $value2=$cache->get('username');

1. 缓存依赖

除了过期设置,缓存数据也可能会因为依赖条件发生变化而失效。例如,如果我们缓存了某些文件的内容,而这些文件发生了改变,我们就应该让缓存的数据失效,并从文件中读取最新内容而不是从缓存中读取。

我们将一个依赖关系表现为一个 CCacheDependency 或其子类的实例。 当调用 set() 时,我们连同要缓存的数据将其一同传入。如下面这段代码的意思就是此值将在30秒后失效,但如果依赖的文件发生了变化则立即失效:
 
Yii::app()->cache->set($id, $value, 30, new CFileCacheDependency('FileName'));

现在如果我们通过调用get() 从缓存中获取 $value ,依赖关系将被检查,如果发生改变,我们将会得到一个 false 值,表示数据需要被重新生成。

如下是可用的缓存依赖的简要说明:

CFileCacheDependency: 如果文件的最后修改时间发生改变,则依赖改变。

CDirectoryCacheDependency: 如果目录和其子目录中的文件发生改变,则依赖改变。

CDbCacheDependency: 如果指定 SQL 语句的查询结果发生改变,则依赖改变。

CGlobalStateCacheDependency: 如果指定的全局状态发生改变,则依赖改变。全局状态是应用中的一个跨请求,跨会话的变量。它是通过 CApplication::setGlobalState() 定义的。

CChainedCacheDependency: 如果链中的任何依赖发生改变,则此依赖改变。

CExpressionDependency: 如果指定的 PHP 表达式的结果发生改变,则依赖改变。此类从版本 1.0.4 起可用。

片段缓存(Fragment Caching) 

片段缓存指缓存网页某片段。例如,如果一个页面在表中显示每年的销售摘要,我们可以存储此表在缓存中,减少每次请求需要重新产生的时间。

要使用片段缓存,在控制器视图脚本中调用 CController::beginCache() 和 CController::endCache() 。这两种方法开始和结束包括的页面内容将被缓存。类似data caching ,我们需要一个编号,识别被缓存的片段。例如下面这段代码如果beginCache() 返回false,缓存的内容将此地方自动插入; 否则,在if语句内的内容将被执行并在endCache()触发时缓存。

......
<?php if($this->beginCache($id)) { ?>
...被缓存的内容...
<?php $this->endCache(); } ?>
......

1. 缓存选项(Caching Options)

当调用beginCache(),可以提供一个数组由缓存选项组成的作为第二个参数,以自定义片段缓存。事实上为了方便,beginCache() 和endCache()方法是[ COutputCache ]widget的包装。因此COutputCache的所有属性都可以在缓存选项中初始化。

有效期(Duration)

也许是最常见的选项是duration,指定了内容在缓存中多久有效。和CCache::set()过期参数有点类似。下面的代码缓存内容片段最多一小时:

......
<?php if($this->beginCache($id, array(&#39;duration&#39;=>3600))) { ?>
...被缓存的内容...
<?php $this->endCache(); } ?>
......

如果我们不设定期限,它将默认为60 ,这意味着60秒后缓存内容将无效。

依赖(Dependency)

像data caching ,内容片段被缓存也可以有依赖。例如,文章的内容被显示取决于文章是否被修改。

要指定一个依赖,我们建立了dependency选项,可以是一个实现[ICacheDependency]的对象或可用于生成依赖对象的配置数组。下面的代码指定片段内容取决于lastModified 列的值是否变化:

<?php if($this->beginCache($id, array(&#39;dependency&#39;=>array(
        &#39;class&#39;=>&#39;system.caching.dependencies.CDbCacheDependency&#39;,
        &#39;sql&#39;=>&#39;SELECT MAX(lastModified) FROM Post&#39;)))) { ?>
...被缓存的内容...
<?php $this->endCache(); } ?

变化(Variation)

缓存的内容可根据一些参数变化。例如,每个人的档案都不一样。缓存的档案内容将根据每个人ID变化。这意味着,当调用beginCache()时将用不同的ID。

COutputCache内置了这一特征,程序员不需要编写根据ID变动内容的模式。以下是摘要。

varyByRoute: 设置此选项为true ,缓存的内容将根据route变化。因此,每个控制器和行动的组合将有一个单独的缓存内容。

varyBySession: 设置此选项为true ,缓存的内容将根据session ID变化。因此,每个用户会话可能会看到由缓存提供的不同内容。

varyByParam: 设置此选项的数组里的名字,缓存的内容将根据GET参数的值变动。例如,如果一个页面显示文章的内容根据id的GET参数,我们可以指定varyByParam为array('id'),以使我们能够缓存每篇文章内容。如果没有这样的变化,我们只能能够缓存某一文章。

有时候,我们希望片段缓存只对某些类型的请求启用。例如,对于某张网页上显示表单,我们只想要缓存initially requested表单(通过GET请求)。任何随后显示(通过POST请求)的表单将不被缓存,因为表单可能包含用户输入。要做到这一点,我们可以指定 requestTypes 选项:

<?php if($this->beginCache($id, array(&#39;requestTypes&#39;=>array(&#39;GET&#39;)))) { ?>
...被缓存的内容...
<?php $this->endCache(); } ?>

2. 嵌套缓存(Nested Caching)

片段缓存可以嵌套。就是说一个缓存片段附在一个更大的片段缓存里。例如,意见缓存在内部片段缓存,而且它们一起在外部缓存中在文章内容里缓存。

<?php if($this->beginCache($id1)) { ?>
...外部被缓存内容...
    <?php if($this->beginCache($id2)) { ?>
    ...内部被缓存内容...
    <?php $this->endCache(); } ?>
...外部被缓存内容...
<?php $this->endCache(); } ?>

嵌套缓存可以设定不同的缓存选项。例如,在上面的例子中内部缓存和外部缓存可以设置时间长短不同的持续值。当数据存储在外部缓存无效,内部缓存仍然可以提供有效的内部片段。然而,反之就不行了。如果外部缓存包含有效的数据, 它会永远保持缓存副本,即使内容中的内部缓存已经过期。

页面缓存 

页面缓存指的是缓存整个页面的内容。页面缓存可以发生在不同的地方。例如,通过选择适当的页面头,客户端的浏览器可能会缓存网页浏览有限时间。Web应用程序本身也可以在缓存中存储网页内容。 在本节中,我们侧重于后一种办法。

页面缓存可以被看作是 片段缓存一个特殊情况 。 由于网页内容是往往通过应用布局来生成,如果我们只是简单的在布局中调用beginCache() 和endCache(),将无法正常工作。这是因为布局在CController::render()方法里的加载是在页面内容产生之后。

如果想要缓存整个页面,我们应该跳过产生网页内容的动作执行。我们可以使用COutputCache作为动作 过滤器来完成这一任务。下面的代码演示如何配置缓存过滤器:

public function filters(){
    return array(
        array(
            &#39;COutputCache&#39;,
            &#39;duration&#39;=>100,
            &#39;varyByParam&#39;=>array(&#39;id&#39;),
        ),
    );
}

上述过滤器配置会使过滤器适用于控制器中的所有行动。 我们可能会限制它在一个或几个行动通过使用插件操作器。 更多的细节中可以看过滤器。

提示: 我们可以使用COutputCache作为一个过滤器,因为它从CFilterWidget继承过来, 这意味着它是一个工具(widget)和一个过滤器。事实上,widget的工作方式和过滤器非常相似。工具widget (过滤器filter)是在action动作里的内容执行前执行,在执行后结束。

6.缓存的使用:动态内容(Dynamic Content)

当使用fragment caching或page caching,我们常常遇到的这样的情况 整个部分的输出除了个别地方都是静态的。例如,帮助页可能会显示静态的帮助 信息,而用户名称显示的是当前用户的。

解决这个问题,我们可以根据用户名匹配缓存内容,但是这将是我们宝贵空间一个巨大的浪费,因为缓存除了用户名其他大部分内容是相同的。我们还可以把网页切成几个片段并分别缓存,但这种情况会使页面和代码变得非常复杂。更好的方法是使用由[ CController ]提供的动态内容dynamic content功能 。

动态内容是指片段输出即使是在片段缓存包括的内容中也不会被缓存。即使是包括的内容是从缓存中取出,为了使动态内容在所有时间是动态的,每次都得重新生成。出于这个原因,我们要求 动态内容通过一些方法或函数生成。

调用CController::renderDynamic()在你想的地方插入动态内容。

<?php if($this->beginCache($id)) { ?>
...被缓存的片段内容...
    <?php $this->renderDynamic($callback); ?>
...被缓存的片段内容...
<?php $this->endCache(); } ?>

在上面的,$callback指的是有效的PHP回调。它可以是指向当前控制器类的方法或者全局函数的字符串名。也可以是一个数组名指向一个类的方法。其他任何的参数,将传递到 renderDynamic()方法中。回调将返回动态内容而不是仅仅显示它。

关于Yii框架缓存的知识这篇文章基本做了一个总结,希望大家在工作当中能用的到。

相关推荐:

memcache在YII框架中的使用方法讲解

Yii framework框架模块开发

Yii2利用表单进行文件上传的实例讲解

Yii2框架中日志的使用方法分析

yii2框架的下载安装图文教程

위 내용은 PHP-yii 프레임워크 캐싱 지식 수집의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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