`
flashdream8
  • 浏览: 678709 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

OSCache 详细使用文档<二>

阅读更多

四、demo

一、对象缓存

1Cache操作类

import java.util.Date;

import com.opensymphony.oscache.base.NeedsRefreshException;

import com.opensymphony.oscache.general.GeneralCacheAdministrator;

public class BaseCache extends GeneralCacheAdministrator {

private int refreshPeriod; //过期时间(单位为秒);

private String keyPrefix; //关键字前缀字符;

private static final long serialVersionUID = -4397192926052141162L;

public BaseCache(String keyPrefix,int refreshPeriod){

super();

this.keyPrefix = keyPrefix;

this.refreshPeriod = refreshPeriod;

}

//添加被缓存的对象;

public void put(String key,Object value){

this.putInCache(this.keyPrefix+&quot;_&quot;+key,value);

}

//删除被缓存的对象;

public void remove(String key){

this.flushEntry(this.keyPrefix+&quot;_&quot;+key);

}

//删除所有被缓存的对象;

public void removeAll(Date date){

this.flushAll(date);

}

public void removeAll(){

this.flushAll();

}

//获取被缓存的对象;

public Object get(String key) throws Exception{

try{

return this.getFromCache(this.keyPrefix+&quot;_&quot;+key,this.refreshPeriod);

} catch (NeedsRefreshException e) {

this.cancelUpdate(this.keyPrefix+&quot;_&quot;+key);

throw e;

}

}

}

2Cache管理类

public class CacheManager {

private BaseCache newsCache;

private static CacheManager instance;

private static Object lock = new Object();

private CacheManager() {

//这个根据配置文件来,初始BaseCache而已;

newsCache = new BaseCache("news",120);

}

public static CacheManager getInstance(){

if (instance == null){

synchronized( lock ){

if (instance == null){

instance = new CacheManager();

}

}

}

return instance;

}

public void putUser(User news) { newsCache.put(news.getId()+"",news); }

public void removeUser(String newsID) { newsCache.remove(newsID); }

public User getUser(int newsID) {

try {

return (User) newsCache.get(newsID+"");

} catch (Exception e) {

System.out.println("getNews>>newsID["+newsID+"]>>"+e.getMessage());

User news = new User(newsID);

this.putUser(news);

return news;

}

}

public void removeAllNews() {

newsCache.removeAll();

}

}

3、对象Bean

public class User {

private int id;

private String name;

private String sex;

private int age;

private Date accessTime; public User(int id) {

super();

this.id = id;

this.accessTime = new Date(System.currentTimeMillis());

}

public String toString() {

return "User info is : id=" + id + " accessTime="

+ accessTime.toString();

}

public User(String name, String sex, int age) {

super();

this.name = name;

this.sex = sex;

this.age = age;

}

public User() {

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public Date getAccessTime() {

return accessTime;

}

public void setAccessTime(Date accessTime) {

this.accessTime = accessTime;

}

}

4、测试类

public class TestObjectCache {

public static void main(String[] args) {

CacheManager cm=CacheManager.getInstance();

TestObjectCache test=new TestObjectCache();

test.print(cm);

}

public void print(CacheManager cm){

User user=null;

for (int i = 0; i < 1000; i++) {

user=cm.getUser(100);

System.out.println("<<"+i+">>: "+user);

if(i==10){

//删除缓存id的对象

cm.removeUser(100+"");

}

if(i==20){

//删除所有缓存的对象

cm.removeAllNews();

}

// 睡眠部分

try {

Thread.sleep(30000);

} catch (Exception e) {

}

}

}

}

 

五、小结及引申

缓存是在提升系统响应时常用的一种技术,在系统缓存上通常采用的是有页面缓存、处理缓存和数据缓存这三种具体的类别,应该说这三种缓存在实现上还是稍有不同,尽管底层的缓存实现是一样的。

页面缓存

页面缓存是指对页面中的内容片断进行缓存的方案。比如页面中有一个部分是显示栏目中的内容的,那么就可以缓存这个部分,在进行第二次请求的时候就直接从缓存中取出这部分的内容(其实就是这部分的html),这种情况下,缓存的作用其实非常明显,在典型的action+service+dao这样的结构中,在采用页面缓存后就意味着不需要经过actionservicedao这些层次的处理了,而是直接就返回了,对于系统响应速度的提升来说是非常明显的。

页面缓存通常采用oscache来进行实现,oscache提供了一个jsp  tag,可通过这个tag来包含需要缓存的内容部分,当然,缓存的这个内容部分需要有对服务器的请求或逻辑计算等的,可想而知,去缓存一段静态html是没有意义的。

其次需要定义缓存的这段内容的key,例如我们要去缓存页面中某个栏目的某页的内容,对于这段内容而言唯一的key就是栏目ID以及当前页数,这样就组成了这段缓存的key了,其实这个部分看起来好像是很简单,但有些时候会很麻烦,要仔细的想清楚这段内容的唯一的标识的key到底是什么,^_^,通常的做法其实可以从action中需要获取的参数或service接口的参数来决定….

页面缓存中还需要做的一个步骤就是通知缓存需要更新,页面缓存和其他缓存稍有不同,需要告诉它,这个时候不能再使用缓存中的内容了,需要从后台再重新获取来生成新的缓存内容,这个其实很简单,因为很难在后台发生变化的时候自己来更新缓存的内容,只能是去通知它,然后让它再次发起请求来生成新的内容放入缓存中。

页面的缓存的使用对于系统的响应速度确实会有很大的提升,在实现页面缓存时最麻烦的主要是缓存的key的定义以及缓存更新的通知,缓存key的定义这个自然框架是没法解决的,不过缓存更新的通知其实在框架中可以考虑一种通知模型的,^_^,就像事件通知那样……..在实际的项目中,可以自己去实现一个这样的通知模型或者就是简单的采用单例方式来标识某个key是否需要更新。

页面缓存在实际的项目中使用非常的多。

处理缓存

处理缓存是指对于actionservicedao或者系统层次中的某方法进行缓存,说直接点,就是对某个类的某个方法的结果做缓存,这样在下次进行完全相同的请求的时候就可以直接取缓存了,这种响应速度的提升也是非常明显的。

处理缓存在现在的情况下其实采用任务的缓存工具包都可以实现,如oscacheehcachejbosscache等,但目前还没有处理缓存框架的出现,这个和处理缓存是否应该存在的意义也是有关系的,处理缓存框架要做到的其实就像拦截一样的方式,和oscache  tag类似。

同样,处理缓存的麻烦也在于怎么样去定义这个key,很多情况下可以根据方法的输入作为key,方法的输出作为key的值,但也会有其他一些复杂的情况,这个时候定义key就会变得复杂些了。

处理缓存同样有通知更新缓存的情况,和页面缓存基本是一样的。

应该说,处理缓存和页面缓存非常的相似,从实现上来说基本是完全一致的,在使用上来讲处理缓存使用的好像不多。

数据缓存

数据缓存估计大家都很熟悉,就是对系统的数据进行缓存的方式,典型的就是Hibernate的一级、二级数据缓存。

数据缓存在实现上如果是用hibernate的话更多的是直接使用hibernate的一级、二级以及查询缓存,如果自己要实现的话可以去参考hibernate的实现机制。

数据缓存的key在一级、二级缓存中采用的都是数据的标识键的值的方式,查询缓存采用的是查询参数、查询语句的方式。

数据缓存的更新则是hibernate在进行存储时直接更新缓存的内容,而对于查询缓存则是采用全部直接清除的方式,这样在下次进行查询时自然会重新去查询,^_^,大家可能会想,为什么页面缓存和处理缓存不采用这样的方式来实现缓存的更新,稍微想想就知道了,在后台发生改变的时候其实是不知道需要移除哪些key的,所以hibernate为了避免这个麻烦,采用的就是当数据一旦发生改变的时候就清除全部的查询缓存,而不是只去清除相关的缓存,其实这里可以采用一种订阅式的模型,呵呵,当然,也增加了框架的复杂度。

数据缓存使用的应该是最多的,效果也是很明显的。

以上三种缓存是目前缓存实现时通常碰到的三种状况,里面按使用的多少来排序应该是:数据缓存、页面缓存和处理缓存;实现的难度上从难到易的顺序应该是:处理缓存、页面缓存、数据缓存;对于系统响应速度提升的效果来说从最好到好的顺序应该是:页面缓存、处理缓存、数据缓存。

 

六、一个典型应用场景

SSH项目应用中,可以以对象的形式来缓存展现给用户的数据信息。对象的缓存要充分利用分组带来的好处(可以分组删除被缓存的对象),这样在执行数据库的CUD操作时,可以调用删除相应组别的缓存对象。

示例代码:

private CacheManager cm;

    private final static String CACHE_KEY_SUB="RetJobs";

    public JobAction() {

      //获取缓存管理对象

       cm = CacheManager.getInstance();

    }

查询部分

       page=(Page<RetJob>)(cm.get(CACHE_KEY_SUB+"_"+currentPage));

       if(page==null){

           //--------------------需要缓存对象部分-----------------------

           page = retJobBaseModel.getJobs(currentPage, pageSize, statusCondition);

           //-------------------------------------------

           //缓存对象(含所属分组信息)

           cm.put(page, CACHE_KEY_SUB+"_"+currentPage,new String[]{CACHE_KEY_SUB});

       }

 

CUD操作部分

setCacheDisabled(CACHE_KEY_SUB);

    private void setCacheDisabled(String group) {

       //通过组别信息来删除缓存的对象。

       cm.removeObjectByGroup(group);

    }

CacheManager

public class CacheManager {

    private BaseCache newsCache;

    private static CacheManager instance;

    private static Object lock = new Object();

    private CacheManager() {

       // 这个根据配置文件来,初始BaseCache而已;

       newsCache = new BaseCache("hrms", 300);

    }

    public static CacheManager getInstance() {

       if (instance == null) {

           synchronized (lock) {

              if (instance == null) {

                  instance = new CacheManager();

              }

           }

       }

       return instance;

    }

    public void put(Object news,String key,String[] groups) {

       newsCache.put(key, news,groups);

    }

    public void remove(String key) {

       newsCache.remove(key);

    }

    public Object get(String key) {

       try {

           return newsCache.get(key);

       } catch (Exception e) {

           return null;

       }

    }

    public void removeAll() {

       newsCache.removeAll();

    }  

    public void removeObjectByGroup(String group){

       newsCache.removeObjectByGroup(group);

    }

}

BaseCache 类增加的2个方法如下:

    // 添加被缓存的对象;

    public void put(String key, Object value,String[] groups) {

       this.putInCache(this.keyPrefix + "_" + key, value,groups);

    }

    //删除该组的缓存对象

    public void removeObjectByGroup(String group){

       this.flushGroup(group);

    }

分享到:
评论

相关推荐

    OSCACHE配置,文档,示例,JAR包

    ### 二、OSCache文档 OSCache的官方文档提供了详细的使用指南、API参考和常见问题解答。文档通常包括以下几个部分: 1. **快速入门**: 教程性质的内容,引导开发者快速了解OSCache的基本用法。 2. **配置指南**: ...

    oscache详细配置文档

    本文将详细介绍 OSCache 的配置和使用方法。 **一、缓存整个页面** OSCache 提供了一个名为 `CacheFilter` 的过滤器,该过滤器用于实现页面级别的缓存。通过在 `web.xml` 文件中配置,我们可以指定哪些页面或一组...

    OSCache配置说明文档

    本文档详细介绍了OSCache的配置与使用,旨在为开发者提供一份全面的参考指南。OSCache是由OpenSymphony开发的开源缓存框架,它为J2EE应用程序提供了高效、灵活的缓存解决方案。 文档介绍 文档目的: 本文档的主要...

    oscache-2.4.1-full.rar

    &lt;br/&gt; }&lt;br/&gt;&lt;br/&gt; }&lt;br/&gt; &lt;br/&gt;}&lt;br/&gt;&lt;br/&gt;&lt;br/&gt; 通过CacheManager类来看怎样缓存对象的,这个类中所用的News只是具体功能的类,我就不贴出来了,你可以自己写一个! view plaincopy to clipboardprint?package...

    教你如何用好oscache的详细文档

    ### 二、osCache 的主要功能 1. **不分页面缓存**:osCache 支持对对象级别的缓存,无论对象大小,都可以被缓存起来。这种模式适用于存储单个数据实体或复杂对象。 2. **整个页面缓存**:对于静态或者几乎不发生...

    OSCache使用文档

    根据提供的信息,我们可以详细解析与OSCache相关的知识点。 ### OSCache简介 OSCache是一个高性能、易于使用的缓存组件,主要用于Web应用程序中数据的缓存管理。它可以极大地提高Web应用的性能,通过减少对数据库...

    ssm整合文档。看着文档自己操作,很简单

    &lt;filter-name&gt;oscache&lt;/filter-name&gt; &lt;filter-class&gt;com.opensymphony.oscache.web.filter.CacheFilter&lt;/filter-class&gt; &lt;init-param&gt; &lt;!--刷新缓存时间--&gt; &lt;param-name&gt;time&lt;/param-name&gt; &lt;param-value&gt;10&lt;/...

    ibatis学习文档

    7. **动态映射**:利用`&lt;if&gt;`、`&lt;choose&gt;`、`&lt;when&gt;`、`&lt;otherwise&gt;`等标签,可以根据条件动态生成SQL语句,增强了SQL的灵活性。 8. **事务管理**:Ibatis支持基于JDBC和JTA的事务管理。默认情况下,它使用JDBC的...

    oscache文档

    ### oscache文档知识点详解 #### 一、OSCache概述及特点 **OSCache**是由**OpenSymphony**设计的一种创新的JSP自定义标签库,主要用于实现现有JSP页面内部的快速内存缓存功能。作为一种广泛应用且高性能的J2EE缓存...

    OsCache2.3.2帮助文档(英文)

    OsCache2.3.2帮助文档(英文)

    iBATIS 2.0 开发指南

    - **动态映射**:使用 `&lt;if&gt;`、`&lt;choose&gt;`、`&lt;foreach&gt;` 等元素构建动态 SQL 语句,提高代码复用性和灵活性。 #### iBATIS 高级特性 - **数据关联**:包括一对多和一对一关联,以及支持延迟加载,提高数据处理效率...

    oscache缓存

    在提供的压缩包中,`oscache-2.4.1.jar`是osCache的二进制库文件,包含了所有必要的类和资源,可以直接引入到Java项目中使用。`docs`目录可能包含osCache的API文档,帮助开发者了解和使用各个类和方法。`src`目录...

    oscache-2.4.1-full

    - `docs`:文档目录,可能包括API文档、用户手册等,帮助开发者更好地理解和使用OSCache。 5. **配置与使用**: 开发者需要根据`etc`目录中的配置文件进行适当修改,以适应自己的应用环境。同时,需要在JSP页面中...

    iBatis2.0文档

    - **动态映射**:支持 SQL 语句的动态构建,例如使用 `&lt;if&gt;`、`&lt;choose&gt;` 等标签。 - **事务管理**: - **基于 JDBC 的事务管理**:适用于简单的事务处理。 - **基于 JTA 的事务管理**:适用于分布式事务。 - **...

    oscache-2.2jar包

    4. **docs**:文档目录,一般包含API文档、用户手册或者开发者指南,帮助开发者理解osCache的使用方法、API接口和最佳实践。 5. **src**:源代码目录,如果提供的话,可以查看osCache的内部实现,这对于学习和调试...

    oscache-2.1.1-full.zip_full_oscache_oscache 2_oscache2

    1. **docs**: 包含osCache的文档,包括用户手册、API参考等,是学习和理解osCache功能的重要资源。 2. **src**: 源代码目录,提供了osCache的全部源代码,便于开发者深入研究和定制。 3. **www.pudn.com.txt**: ...

Global site tag (gtag.js) - Google Analytics