PHP 文件缓存数组的实现
来源:互联网 发布:社交软件大全 编辑:程序博客网 时间:2024/04/28 04:15
在一个试验性项目中,我需要从 sqlite3 数据库中随机读取一条记录给用户,要读取的数据表现在有23850条记录,按 skemu 分类,一般每个 skemu 下有 3000多条记录,原先我使用了 sqlite3 的随机查询语句:
- $query="SELECT * FROM shiti WHERE skemu = " . intval($kemuid) . " order by random() limit 1";
然后在我现在用的电脑上没有感觉到明显迟延,但当我把服务器换到一个 P4 1.8G 512M内存的机器上运行时,感觉数据读取速度非常慢,需要2、3秒才能读出数据。如果每次用户要取一条随机记录,都执行这样一个随机查询的话,瓶颈将会出现在数据库查询过程中,难以想像这样的性能如何来适应众多用户的同时访问。为此,我考虑减少数据库的查询次数,先把记录 id 取出来放到数组中,然后从中再来随机取一条记录,同时存为文件供以后读取,这样以减少数据库查询的次数。
以下函数实现读出 id 集:
- static function getIDs($kemuid)
- {
- $cachefile="cache/" . $kemuid . ".cache";
- $datas=array();
- if (!file_exists($cachefile)||time() < (filemtime($cachefile) + 14400))
- //缓存不存在或超过4小时
- {
- global $data;
- //读取 id 集
- $query="SELECT sid FROM shiti WHERE skemu = " . intval($kemuid);
- $res = $data->query($query);
- while($r = $data->fetchArray($res))
- {
- $datas[]=$r['sid'];
- }
- //写入缓存
- file_put_contents($cachefile,serialize($datas));
- }
- else
- {
- //读出缓存
- $fp = fopen($cachefile,'r');//读
- $datas = unserialize(fread($fp,filesize($cachefile)));//反序列化,并赋值
- }
- return $datas;
- }
调用它的读取随机记录函数:
- static function getRondam($kemuid)
- {
- global $data;
- $ids=self::getIDs($kemuid);
- $index=rand(0,count($ids)-1);
- $id=$ids[$index];
- $query="SELECT * FROM shiti WHERE sid = " . intval($id);
- $res = $data->query($query);
- $r = $data->fetchArray($res);
- $r['da']=$s;
- return $r;
- }
这样比每次执行随机查询快多了,但是还是要比生成一个HTML缓存要慢一点,但那样需要把更多数据暴露给客户端,或是存储更多缓存,我想这已经是一个比较均衡的方案了。
这个解决办法的要点在于数组的序列化与反序列化,大家应该很容易看得懂。
0 0
- PHP 文件缓存数组的实现
- PHP 文件缓存数组的实现
- php实现文件缓存类
- PHP实现文件缓存转化内存缓存
- PHP实现文件缓存转内存缓存
- PHP缓存的实现
- PHP缓存的实现
- PHP缓存的实现
- PHP缓存的实现
- PHP缓存的实现
- PHP缓存文件的分页
- PHP的文件缓存机制
- PHP的文件缓存机制
- php文件缓存技术实现代码
- PHP通过文件存储来实现缓存
- 【php缓存技术】php缓存技术的多种实现方法
- 【php缓存技术】php缓存技术的多种实现方法
- 【php缓存技术】php缓存技术的多种实现方法
- 学习资源
- 北大ACM题分类
- hdu3463
- 【Linux编程】socket编程
- 一个求幂的小trick
- PHP 文件缓存数组的实现
- php redis
- 设计模式之迭代器模式(Iterator)摘录
- Cstore project 的总结
- Training--支持不同的设备
- hdu 1518 Square
- 文本文件与二进制文件
- callable runnable future 之间的API(接口定义的不同)
- Training--支持不同的语言