因为工作原因,前一阵子接触到了memcache。随便写点自己的理解留作纪念。不负责任言论。
memcache主要用来缓解大规模并发访问时候数据库的压力。通过在内存中建立hashtable似的存储区域,进行快速无阻塞的IO操作。同时又有着很低的cpu占用率。只要有内存,一切好说。但是但是用的时候应该如何去利用这个缓冲区,是个比较棘手的问题。我只有一点点自己简单的想法:
在我的那个项目中,数据库查询在数据库操作中占据绝对大的比例。但是有三种情况:
数据更新的十分缓慢,类似通告,通知,新闻等。
会伴随着对数据表的增删改而进行改动的数据,经常性的变化。
session数据。
对于第一种,我的想法是利用memcache自己的生命周期。设置一个之间,到期自动更新即可。因为不用考虑到缓冲区数据和实际数据之间版本不同步的问题,比较好操作。
第二种,数据表会进行改动,而且对数据的实时性要求比较高。之前小组讨论过很多实现方式,最后还是决定用别人用过的:将memcache的更新操作和对数据表的insert、update、delete操作捆绑。直接对sql文取md5码,将此码当作key存储在缓冲区中,当数据库发生变动的时候,实时更新缓冲区数据。
第三种,单纯的配置就好了吧。。。
另外,java和php间怎样通过memcache进行session共享,还有待调查。大方向是用json保存数据什么的。。
虽然命中率可能不高,以后再调查下相关文献结合业务看看有没有改进方法。