[原创]浅谈我对JCS 的理解_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3172 | 回复: 0   主题: [原创]浅谈我对JCS 的理解        下一篇 
panpan.nie
注册用户
等级:大校
经验:4754
发帖:217
精华:2
注册:1970-1-1
状态:离线
发送短消息息给panpan.nie 加好友    发送短消息息给panpan.nie 发消息
发表于: IP:您无权察看 2014-12-3 9:09:52 | [全部帖] [楼主帖] 楼主

JCS 是Java 中缓存的一种实现,支持将数据缓存到内存和硬盘中,支持设置缓存对象的有效时长。

我认为可以这么理解JCS:客户端向服务器发出请求,服务器就先去缓存中查一下有没有客户端请求的数据,有则直接使用;没有则服务器去连接数据库查询数据,然后将数据传给用户的同时也存到缓存中,供下一次使用。若是缓存满了就根据所设置的调度算法(如:最近最少算法)去删除缓存中的对象,若是缓存中的对象过了有效时长,也将被删除。

JCS 在项目中的实现

1、所需要使用到的架包如下:

commons-collections-3.2.jar
commons-lang-2.5.jar
commons-logging-1.1.1.jar
concurrent-1.3.4.jar
jcs-1.2.7.9.jar


2、JCS 配置文件

配置JCS 就是简单地创建和填充一个cache.ccf 文件,这个文件定义缓存应该使用哪些区域,以及这些区域的属性或选项。根据应用程序的需求,配置这个文件可以快速扩展缓存。在JCS的配置文件中(WEB-INF/classes/cache.ccf),有一个默认配置(default),也可以对每个缓冲区(region)单独配置,没有单独配置特性的缓冲区将使用默认的配置

例如cache.ccf

# optional region "testCache1" specific configuration settings
jcs.region.testCache1=
jcs.region.testCache1.cacheattributes=org.apache.jcs.engine.CompositeCacheAttributes
jcs.region.testCache1.cacheattributes.MaxObjects=1000
jcs.region.testCache1.cacheattributes.MemoryCacheName=org.apache.jcs.engine.memory.lru.LRUMemoryCache
jcs.region.testCache1.cacheattributes.UseMemoryShrinker=false
jcs.region.testCache1.elementattributes.IsEternal=false
jcs.region.testCache1.elementattributes.MaxLifeSeconds=180
jcs.region.testCache1.elementattributes.IsSpool=false
jcs.region.testCache1.elementattributes.IsLateral=false
jcs.region.testCache1.elementattributes.IsRemote=false


3、JCS 的实现

可以将JCS当做是一个特殊的Map来理解,其赋值、取值、移除值的方式均与Map相同。

import org.apache.jcs.JCS;
import org.apache.jcs.access.exception.CacheException;
public class CacheManage
{
      public static void main(String[] args)
      {
            JCS cache=null;
            try
            {
                  cache = JCS.getInstance("testCache1");
                  String key = "test";
                  String value = "abcd";
                  for(int i =0; i<1000;i++)
                  {
                        cache.put(key+i, value+i);
                  }
            }
            catch (CacheException e)
            {
                  // TODO Auto-generated catch block
                  e.printStackTrace();
            }
            System.out.println("test100:"+cache.get("test100"));
            System.out.println("test300:"+cache.get("test300"));
            System.out.println("test1000:"+cache.get("test1000"));
      }
}


从上述实现的例子中,我们可以看出,使用JCS.getInstance()取的一个在cache.ccf 定义过得缓存域即可使用该缓存了。在多个类中是会共享缓存中的数据的。

JCS的理论知识:JCS 介绍

该贴被panpan.nie编辑于2014-12-3 9:11:51



赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论