php数据缓存到文件类设计
// 自定义缓存类
class Cache_Filesystem {
// 缓存写保存
function set ($key, $data, $ttl) {
//打开文件为读/写模式
$h = fopen($this->get_filename($key), 'a+');
if (!$h) throw new Exception("Could not write to cache");
flock($h, LOCK_EX); //写锁定,在完成之前文件关闭不可再写入
fseek($h, 0); // 读到文件头
ftruncate($h, 0); //清空文件内容
// 根据生存周期$ttl写入到期时间
$data = serialize(array(time()+$ttl, $data));
if (fwrite($h, $data) === false) {
throw new Exception('Could not write to cache');
}
fclose($h);
}
// 读取缓存数据,如果未取出返回失败信息
function get ($key) {
$filename = $this->get_filename($key);
if ( !file_exists( $filename ) ) {
return false;
}
$h = fopen($filename, 'r');
if (!$h) return false;
// 文件读取锁定
flock($h, LOCK_SH);
$data = file_get_contents($filename);
fclose($h);
$data = @unserialize($data);
if ( !$data ) {
// 如果反序列化失败,则彻底删除该文件
unlink($filename);
return false;
}
if (time() > $data[0]) {
// 如果缓存已经过期,则删除文件
unlink($filename);
return false;
}
}
// 清除缓存
function clear ( $key ) {
$filename = $this->get_filename($key);
if (file_exists($filename)) {
return unlink($filename);
} else {
return false;
}
}
// 获取缓存文件
private function get_filename ($key) {
return './cache/' . md5($key);
}
}
调用
require './4.3-cache_class.php';
// 创建新对象
$cache = new Cache_Filesystem(); function getUsers () {
global $cache; // 自定义一个缓存key唯一标识
$key = 'getUsers:selectAll'; // 检测数据是否缓存
if ( !$data = $cache->get( $key ) ) {
// 如果没有缓存,则获取新数据
$db_host = 'localhost';
$db_user = 'root';
$db_password = 'root';
$database = 'ecshop_test'; $conn = mysql_connect( $db_host, $db_user, $db_password);
mysql_select_db($database); //执行sql查询
$result = mysql_query("select * from ecs_users");
$data = array(); // 将获取到的数据放入数组$data中
while ( $row = mysql_fetch_assoc($result)) {
$data[] = $row;
}
// 保存该数据到缓存中,生存周期为10分钟
$cache->set($key, $data, 10);
} return $data;
} try { $users = getUsers();
print_r($users);
$key = 'getUsers:selectAll';
//$cache->clear($key); } catch (Exception $e) {
print $e->getMessage();
}
php数据缓存到文件类设计的更多相关文章
- json和xml封装数据、数据缓存到文件中
一.APP的通信格式之xml xml:扩展标记语言,可以用来标记数据,定义数据类型,是一种允许用户对自己标记语言进行定义的源语言.XML格式统一,扩平台语言,非常适合数据传输和通信,业界公认的标准. ...
- mysql批量插入数据的基类
自己设计的一个mysql数据库批量添加数据的基类.用于批量向mysql数据库添加数据,子类实现起来很简单,自测性能也还不错. 1.基类实现-BatchAddBase using System.Coll ...
- 水果项目第1集-想法>需求->功能->数据库设计->类设计
懒,懒人,我是个懒人. 懒人想做点事,总是拖拖拉拉,迟迟没有开始. 很久很久以前,就想做属于自己的产品,但是至今还没有一个属于自己的产品. 两年前,终于想好,要做一个网上卖水果的系统,手机上点点,水果 ...
- YTU 2602: 熟悉题型——类设计( 矩形类定义【C++】)
2602: 熟悉题型--类设计( 矩形类定义[C++]) 时间限制: 1 Sec 内存限制: 128 MB 提交: 183 解决: 119 题目描述 定义一个矩形类,数据成员包括左下角和右上角坐标 ...
- Java 类设计技巧
摘自<Java核心技术>卷I:基础知识 p140 第4章对象与类 - 类设计技巧 1)一定将数据设计为私有. 最重要的是:绝对不要破坏封装性.有时候,需要编写一个访问器方法或更改器方法,但 ...
- Java11-java基础语法(十)类设计综合案例
Java11-java语法基础(十)类设计综合案例 一.类综合设计方法 1.类设计步骤 (1)分析数据成员 (2)分析成员方法和构造方法 (3)画出类图 (4)编码测试 2.具体问题 1)分析数据成员 ...
- JFreeChart绘制XY折线图(工具类设计)
准备用Java写通信的仿真平台作为毕业设计,相比matlab绘图,Java绘图需要自己去写很多工具类,博主在这采用了JFreeChart的开源解决方案,摸索着自己写了一个XY折线图工具类,话不多说贴源 ...
- 如何导出标准模板库(STL)类的实例化和包含STL类对象数据成员的类
本文翻译自 https://support.microsoft.com/zh-cn/help/168958/how-to-export-an-instantiation-of-a-standard-t ...
- 关于项目中的DAL数据接入层架构设计
摘要:项目中对关系型数据库的接入再寻常不过,也有海量的ORM工具可供选择,一个一般性的DAL数据接入层的结构却大同小异,这里就分享一下使用Hibernate.Spring.Hessian这三大工具对D ...
随机推荐
- DISTINCT 去重仍有重复的分析
logger日志报错 插入数据时违反主键唯一约束 org.springframework.dao.DuplicateKeyException: ### Error updating database. ...
- python selenuim如何判断下拉框是否加载出来,超过时间不再等待
s_flag = True time_start = time.time() while s_flag: doc = etree.HTML(unicode.encode(driver.page_sou ...
- Maven命令参数
命令参数 备注 mvn -v --version 显示版本信息; mvn -V --show-version 显示版本信息后继续执行Maven其他目标; mvn -h --help 显示帮助信息; m ...
- (四)启用HTTPS
安全规范中有一条是要求尽量使用https而弃用http(新Chrome将标记非HTTPS网站为不安全),其实启用https和之前的ipv6改造一样,并不是什么高难度或者工作流繁多的的改造,只需将中间件 ...
- linux下SVN CVS命令大全
1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn: // 192.168. 1.1 / pro / doma ...
- C语言实例解析精粹学习笔记——32
实例32: 编制一个包含姓名.地址.邮编和电话的通讯录输入和输出函数. 思路解析: 1.用结构体来完成姓名.地址.邮编和电话的组合. 2.结构体指针的使用. 3.malloc的使用 4.scanf函数 ...
- Python3 函数return
# def logger(): # f = open("loge.txt","a") # f.write("2017-09-15 exec funct ...
- 0301001_Lesson1&2
Lesson 1 Excuse me! 对不起! Listen to the tape then answer this question.Whose handbag is it?听录音,然后回答问题 ...
- sqlserver 数据查询效率优化
首先优化是具体情况具体分析,从硬件.改进表结构.索引.改进sql查询语句.存储方式都有关系等多方面入手 比如单表数据量(100w-200w条)不大的情况下,查询效率慢 可以从优化sql语句.对多个排序 ...
- Java输出日历写法
package TestString_2; import java.text.ParseException;import java.util.Calendar;import java.util.Gre ...