这一篇将以介绍一个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[i] = SockIOPool.getInstance(poolNames[i]);
this.pools[i].setServers(servers);
this.pools[i].setWeights(weights);
this.pools[i].setInitConn(initConn);
this.pools[i].setMinConn(minConn);
this.pools[i].setMaxConn(maxConn);
this.pools[i].setMaxIdle(maxIdle);
this.pools[i].setMaxBusyTime(maxBusyTime);
this.pools[i].setMaintSleep(maintSleep);
this.pools[i].setNagle(ifNagle);
this.pools[i].setSocketTO(socketTO);
this.pools[i].setSocketConnectTO(socketConnectTO);
this.pools[i].setFailover(ifFailOver);
this.pools[i].setFailback(ifFailback);
this.pools[i].setAliveCheck(ifAliveCheck);
this.pools[i].initialize();
this.mcs[i] = new MemCachedClient(poolNames[i]);
}
}
}

  

第四步、新建一个基类以供所用继承它的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 = "goodsDaoImpl")
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;
}
}

  原文链接 :http://blog.csdn.net/sup_heaven/article/details/32728477/

memcached在项目中的应用的更多相关文章

  1. memcached真实项目中的应用

    上一篇memcached介绍及基本使用介绍了memcached的一些基本概念和一个范例.这一篇将介绍一个memcached在实际项目中的应用

  2. 在Java项目中部署使用Memcached[转]

    在项目中使用到Memcached主要的目的是,通过缓存数据库查询结果,减少数据库访问次数,从而提高动态.数据库驱动网站的速度.提高可扩展性.Memcached是一个高性能的分布式内存对象缓存系统,基于 ...

  3. Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  4. 【转】 Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  5. 【转载】Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  6. Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作 - Edison Chou

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  7. Memcached在.net中的应用

    一.MemCached下载 服务端下载:http://memcachedproviders.codeplex.com/ client下载:path=/trunk">http://sou ...

  8. Memcached在.Net中的基本操作

    Memcached在.Net中的基本操作 一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅 ...

  9. 在.NET项目中使用PostSharp,使用CacheManager实现多种缓存框架的处理

    在前面几篇随笔中,介绍了PostSharp的使用,以及整合MemoryCache,<在.NET项目中使用PostSharp,实现AOP面向切面编程处理>.<在.NET项目中使用Pos ...

随机推荐

  1. selenium2使用记录

    安装 pip install selenium web phantomjs下载 :http://phantomjs.org/download.html 浏览器驱动下载:http://www.selen ...

  2. ios在项目中打开word文档、ppt等总结

    最近在项目开发中遇到下载附件文档预览需求,在这里总结一下我的实现方法,本文最后会附带我写的demo下载地址 这里我总结了三种实现方法(1)用webView预览(2)通过UIDocumentIntera ...

  3. react重学

    知识点一:react解析中 return {__html:rawMarkup}; 这里的html前边用的是双下划线(谢谢学妹的指点)

  4. python3数据结构

    列表 list.append(x) 把一个元素添加到列表的结尾,相当于a[len(a):]=[x] list.extend(L) 将一个给定列表中的所有元素都添加到另一个列表中,相当于a[(len): ...

  5. 第一百二十一节,JavaScript事件绑定及深入

    JavaScript事件绑定及深入 学习要点: 1.传统事件绑定的问题 2.W3C事件处理函数 3.IE事件处理函数 4.事件对象的其他补充 事件绑定分为两种:一种是传统事件绑定(内联模型,脚本模型) ...

  6. 《css揭秘》

    <css揭秘> 第一章:引言 引言 案例们 第二章:背景与边框 背景和边框 半透明边框(rgba/hsla.background-clip) 多重边框(box-shadow) 灵活的背景定 ...

  7. db2 备份还原

    一.导入导出 ixf: db2 export to /tmp/xxx.csv of ixf lobs to . xml to . modified by codepage=1208 "sel ...

  8. UNIX基础--安装应用程序: Packages 和 Ports

    Packages and Ports 概述 FreeBSD 将许多系统工具捆绑作为基本系统的一部分.另外,FreeBSD 提供了两种补充的技术来安装第三方软件:FreeBSD Ports Collec ...

  9. java 的对象拷贝(有深浅拷贝两种方式,深拷贝实现的两种方式(逐层实现cloneable接口,序列化的方式来实现))

    Java提高篇--对象克隆(复制)(转自:http://www.cnblogs.com/Qian123/p/5710533.html#_label0)   阅读目录 为什么要克隆? 如何实现克隆 浅克 ...

  10. C#用 excel 作为模板打印

    //打印操作,套打.打印.预览        enum PrintFlag        {            /// <summary>            /// 套打,只打印没 ...