读书人

membase get 的使用

发布时间: 2012-07-08 17:43:44 作者: rapoo

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。

读书人网 >其他数据库

热点推荐