日期:2014-05-16  浏览次数:20417 次

membase get 的应用
最近有个项目需要模拟session机制,存储到membase中,供多个程序认证和单点登录使用。

需要对membase 中set进的某key实时更新有效时间。

1.cache.getAndTouch  对有效期有更新的作用。
MemcachedClient cache = new MemcachedClient(Arrays.asList(URI.create("http://172.16.2.47:8091/pools")), "login_session","login_session");
   
    OperationFuture<Boolean> o = cache.set("11111",5,"11111aaaaaabbbccccDDD");
   
    for(int i =0;i<10;i++){
   
    Thread.sleep(1000*4);
    CASValue a = cache.getAndTouch("11111", 5);
    System.out.println(a.toString()+"-------");
    String t = (String)a.getValue();
    System.out.println(new Date()+" 时间 ====》"+i+"内容"+t);
    }
每次都可以访问到key查询的value!

2.cache.getAndLock

MemcachedClient cache = new MemcachedClient(Arrays.asList(URI.create("http://172.16.2.47:8091/pools")), "login_session","login_session");
   
    OperationFuture<Boolean> o =cache.set("11111",20,"11111aaaaaabbbccccDDD");
   
    for(int i =0;i<10;i++){
   
    CASValue s = cache.getAndLock("11111", 4);
    String t = (String)s.getValue();
    Thread.sleep(1000*4);

    System.out.println(new Date()+" 时间 ====》"+i+"内容"+t);
   
    }
前5次可以取出key的值,只有为null。