memcache的应用策略

因为工作原因,前一阵子接触到了memcache。随便写点自己的理解留作纪念。不负责任言论。

memcache主要用来缓解大规模并发访问时候数据库的压力。通过在内存中建立hashtable似的存储区域,进行快速无阻塞的IO操作。同时又有着很低的cpu占用率。只要有内存,一切好说。但是但是用的时候应该如何去利用这个缓冲区,是个比较棘手的问题。我只有一点点自己简单的想法:

在我的那个项目中,数据库查询在数据库操作中占据绝对大的比例。但是有三种情况:

  1. 数据更新的十分缓慢,类似通告,通知,新闻等。

  2. 会伴随着对数据表的增删改而进行改动的数据,经常性的变化。

  3. session数据。

对于第一种,我的想法是利用memcache自己的生命周期。设置一个之间,到期自动更新即可。因为不用考虑到缓冲区数据和实际数据之间版本不同步的问题,比较好操作。

第二种,数据表会进行改动,而且对数据的实时性要求比较高。之前小组讨论过很多实现方式,最后还是决定用别人用过的:将memcache的更新操作和对数据表的insert、update、delete操作捆绑。直接对sql文取md5码,将此码当作key存储在缓冲区中,当数据库发生变动的时候,实时更新缓冲区数据。

第三种,单纯的配置就好了吧。。。


另外,java和php间怎样通过memcache进行session共享,还有待调查。大方向是用json保存数据什么的。。


虽然命中率可能不高,以后再调查下相关文献结合业务看看有没有改进方法。

转载于:https://my.oschina.net/u/1770057/blog/263282

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值