静态缓存
要使用静态缓存功能,需要开启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操作进行静态缓存
'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方法不传入type参数初始化的话,则读取配置文件中设置的DATA_CACHE_TYPE参数值作为默认类型。同样的道理,prefix参数如果没有传入会读取配置文件的DATA_CACHE_PREFIX参数值,expire参数没有传入则读取DATA_CACHE_TIME配置值作为默认。
新闻热点
疑难解答