memcached 项目中的使用

http://ljh2008.iteye.com/blog/632850

http://ljh2008.iteye.com/blog/636347

摘要:

缓存对提高系统性能至关重要,缓存什么对象,采用什么样的缓存策略,都要根据不同的需求而定,不能一概而论,大家要根据不同的项目需求,选择最佳的缓存方案

在java程序中的访问。
首先要强调一下,放入memcached中缓存的对象,必须以键值对(key/value)的方式放入,取的时候根据key来取,但memcached有 几个自己的特殊要求:key必须为String,即字符串类型;而要缓存的对象必须要实现Serializable序列化接口。
在英语复读网(www.fudu365.com)的播放器中,当用户将鼠标停留到某个单词上时,系统要弹出该单词的解释及音标,由于项目组在开发时并没有 找到一套合适的词库,我们的解决思路是:当有用户查询时,服务器向第三方翻译网站提交单词,再从返回的结果中解析出单词解释及发音。此查询过程相当费时, 且在网络状态不好时表现不佳,但在当时这也许是最好的解决办法了。
Word对象是我们封装的单词音标及解释对象,该对象实现Serializable接口。当用户查询某个单词时,我们先会在Memcached缓存中查 找,如果没有找到,则向数据库查询,如果数据库找到,将写入缓存 ,如果数据库中也没有找到,再向第三方翻译网站提交,得到结果后返回给用户后,同时要把该单词存入数据库,同时放入 Memcached缓存,下次有用户查询同样的单词时,效率将会得到非常大的提升。

最后还有一个问题要考虑,就是在操作系统重新启动后,Memcached中缓存的数据将不再存在,为了效率考虑,你可以在应用服务器启动时,将所有的单词 对象全部读出,再添加到Memcahced中。

猜你喜欢

转载自fhqllt.iteye.com/blog/1559550
今日推荐