使用PHP的站点系统,在面对大数据量的时候不得不引入缓存机制。有一种简单有效的办法是将PHP的对象缓存到文件里。下面我来对这3种缓存方法进行说明和比较。
第一种方法:JSON
JSON缓存变量的方式主要是使用json_encode和json_decode两个php函数。json_encode可以将变量变成文本格式,这样就可以存到文件里。
使用样例如下:
// Store cache file_put_contents($cachePath, json_encode($myDataArray)); // Retrieve cache $myDataArray = json_decode(file_get_contents($cachePath));
优势:
- 变量序列化后依然可读
- 可以给其他系统使用,因为JSON格式是标准的
劣势:
- 只对UFT-8的数据有效,其他编码可能不能很好工作
- 只对stdClass类的示例有效
第二种方法:序列化
序列化的方式主要使用serialize和unserialize这2个函数,序列化的方式和JSON都是,都是以文本方式存储。
使用示例
// Store cache file_put_contents($cachePath, serialize($myDataArray)); // Retrieve cache $myDataArray = unserialize(file_get_contents($cachePath));
优势:
- 允许非UTF-8的变量
- 支持除了stdClass 示例外的其他实例
劣势:
- 编码后的文本对人来说是不可读的
- 无法被其他语言的系统引用
第三种方法:Var_export
这种方式是用var_export函数将变量内容打印到一个PHP文件里,使用include的方式来重新获取变量内容。因此生成的缓存文件时一个php文件,内容如下
<?php return /*var_export的输出*/; ?>
使用示例:
// Store cache file_put_contents($cachePath, "<?php\nreturn " . var_export($myDataArray, true) . ";"); // Retrieve cache $myDataArray = include($cachePath);
- 使用编码函数对数据进行10次编码
- 计算编码后的数据的大小
- 对编码后的数据进行10次解码
结论
2.53GHz, 4GB, Ubuntu linux, PHP 5.3.0RC4.这样配置的笔记本上,测试的结果如下:
上面2个图表示100%是最佳的,var_export在编码和解码的性能上不佳。建议在数据量小的时候使用序列化的方法,如果数据量非常大,那就要考虑数据结构的问题了。
文章出处:http://www.opstool.com/article/262