设为首页 收藏本站
查看: 700|回复: 0

[经验分享] memcached真实项目中的应用

[复制链接]

尚未签到

发表于 2015-11-18 13:11:47 | 显示全部楼层 |阅读模式
  上一篇memcached基本配置与使用http://blog.iyunv.com/sup_heaven/article/details/32337711介绍了memcached的一些基本概念和一个范例。
  这一篇将以介绍一个memcached在项目中的应用。假设我们有一个web应用,里面有商品信息,文章信息,评论信息,其他信息,我们希望对其做缓存,那么我们在ServiceImpl层就不在调用DAOmpl层,而是调用CacheImpl层,在CacheImpl层中判断要取出的商品信息是否已经在缓存中,如果在了,那么直接从缓存中去,如果没有这个时候还是从数据库中取,同时将它放到缓存中,以便下次使用。
  第一步、新建一个常量类,用于上面的四种信息的在数组中的索引。
  

public class MemcachedConstant {
public static final int MEMCACHED_GOODSDETAIL = 0;
public static final int MEMCACHED_ARTICLEDETAIL = 1;
public static final int MEMCACHED_COMMENTDETAIL = 2;
public static final int MEMCACHED_OTHERDETAIL = 3;
}

第二步、由于有大量的商品信息,我们在放入缓存时必须给定一个key,那么我们最好规范的命名不同类别的key,如商品的key就是商品的前缀加上商品的编号。  
  

public class MemcachedKeyUtil {
private static final String GOODS_KEY_PREFIX = "goods_";
public static String getGoodsKey(long goodsId) {
return GOODS_KEY_PREFIX + goodsId;
}
}

第三步、我们建一个和上一篇文章中一样的工具类,用于新建pool、client,操作缓存等。这里再强调一下,一个pool关联多个server(就是会根据权重将缓存放在这些servers上),一个client会通过poolName关联具体的pool。  
  

public class MemcachedUtil {
private int MEMCACHED_SERVER_NUM = 4;
private SockIOPool[] pools = new SockIOPool[MEMCACHED_SERVER_NUM];
private MemCachedClient[] mcs = new MemCachedClient[MEMCACHED_SERVER_NUM];
private final String[] poolNames = new String[] { "GOODSDETAIL_POOL", "", "", "" };
private static MemcachedUtil instance;
private MemcachedUtil() {
this.init();
}
// 单例
public static MemcachedUtil getInstance() {
if (MemcachedUtil.instance == null) {
synchronized (MemcachedUtil.class) {
if (MemcachedUtil.instance == null) {
MemcachedUtil.instance = new MemcachedUtil();
}
}
}
return MemcachedUtil.instance;
}
public Object get(int index, String key) {
return this.mcs[index].get(key);
}
public boolean set(int index, String key, Object value) {
return this.mcs[index].set(key, value);
}
public boolean delete(String key) {
return this.mcs[index].delete(key);
}
public MemCachedClient getMemCachedClient(int index) {
return this.mcs[index];
}
public void init() {
for (int i = 0; i < MEMCACHED_SERVER_NUM; ++i) {
this.pools = SockIOPool.getInstance(poolNames);
this.pools.setServers(servers);
this.pools.setWeights(weights);
this.pools.setInitConn(initConn);
this.pools.setMinConn(minConn);
this.pools.setMaxConn(maxConn);
this.pools.setMaxIdle(maxIdle);
this.pools.setMaxBusyTime(maxBusyTime);
this.pools.setMaintSleep(maintSleep);
this.pools.setNagle(ifNagle);
this.pools.setSocketTO(socketTO);
this.pools.setSocketConnectTO(socketConnectTO);
this.pools.setFailover(ifFailOver);
this.pools.setFailback(ifFailback);
this.pools.setAliveCheck(ifAliveCheck);
this.pools.initialize();
this.mcs = new MemCachedClient(poolNames);
}
}
}

第四步、新建一个基类以供所用继承它的CacheImpl直接调用MemcachedUtil里的方法,如果不写该类那么在CacheImpl中会有很多重复的操作MemcachedUtil的代码。  
  

public class MemcachedSupport {
public boolean setDetailData(String key, Object value) {
return MemcachedUtil.getInstance().set(MemcachedConstant.MEMCACHED_DETAIL, key, value);
}
public Object getDetailData(String key) {
return MemcachedUtil.getInstance().get(MemcachedConstant.MEMCACHED_DETAIL, key);
}
public boolean deleteDetailData(String key) {
return MemcachedUtil.getInstance().delete(MemcachedConstant.MEMCACHED_DETAIL);
}
}


第五步、新建一个GoodsCacheImpl,该类的作用就是一开始所说的,娶不到缓存,就调用DAO查询并放入缓存,如果缓存中有就直接从缓存中拿。  
  

public class GoodsCacheImpl extends MemcachedSupport{
@Resource(name = &quot;goodsDaoImpl&quot;)
private GoodsDao goodsDao;
public Goods selectGoodsById(long goodsId) {
Goods goods = null;
String goodsKey = MemcachedKeyUtil.getGoodsKey(goodsId);
goods = (Goods) getDetailData(goodsKey);
if (goods == null) {
goods = goodsDao.selectGoodsById(goodsId, false);
if (goods != null) {
setDetailData(goodsKey, goods);
}
}
return goods;
}
}

这样就在你的应用中使用了memcached,不过上面的只是部分代码,跑不起来的哦。  

版权声明:本文为博主原创文章,未经博主允许不得转载。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-140731-1-1.html 上篇帖子: memcached 常用命令及使用说明 下篇帖子: 命中率问题:memcached server LRU 深入分析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表