关于memcache的使用(入门级问题),memcache已经配置好,如何才能通过使用它来加快访问速度?
如题
网上看了很多资料 大都是关于memcache配置安装 还有函数列表的
现在已经配置好 用echo $memcache->getVersion();也可以打印出版本了
该如何进行进一步的操作 来使响应速度增加
比如我现在我已经知道一条很复杂的sql语句执行时间很久
如何针对这条sql语句进行操作?
如果描述不够清楚请说一下我尽量描述...
谢谢~~
------解决方案--------------------估计你是把应用场景想错了...
sql的问题首先是优化语句
当然你可以考虑将表放到临时内存表里处理
------解决方案--------------------
memcache可以分担mysql的压力。
比如你有select的读语句要执行,每次读数据库前先从memcache缓存读,若是读不到再从mysql读,并将内容写到缓存,以便下次从缓存读。
memcache说白了可以降低数据库服务的读压力,而且是缓存,读快且压力小。
而“比如我现在我已经知道一条很复杂的sql语句执行时间很久”,要是想让它快你只能优化sql语句。
若是这句是个读操作,那么你可以写缓存,以后读的话就非常快了。
另外,缓存要注意一点,数据库update和delete的时候,缓存也要更新。~~~
------解决方案--------------------memcache 不可以缓解数据库的压力
如果那打算将查询结果放在 memcache 中供下次使用,那么下次你得到的不就总是旧的数据吗?
如果还要去检查库中数据是否更新的话,那要缓存做什么?
那么 memcache 适合由于什么样的场景呢?
当你的程序已经在使用文件或数据库缓存中间结果时,那么使用 memcache 可以提升缓存的性能
------解决方案--------------------缓存主要应用于某个时间段不会更新而且经常连接数据库的页面或者程序,比如天气预报,商城的每日促销页面等等,这些访问量会比较大,而且不长更新使用缓存时限,比如每天的8时更新或者分几个时间段,看自己的需求了
------解决方案--------------------你这表述,memcache不是用来优化sql语句的,
它是用来临时
存储访问数据库后得到的数据,第一次获得数据后存储起来,下次访问的时候就不需要查询数据库,而是直接从内存中拿,从而达到减轻数据库访问压力.
而memcache相当于是面向对象的访问接口(内存缓存的过程式程序)
code中类似这样的逻辑
if($mem->get('key')){ // 判断是否已经存储
// 已存储 从内存中获取
}else{
$mem->set('key','value') // 还没有存入缓存 存入