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。