扫码一下
查看教程更方便
cas 代表 check-and-set 或 compare-and-swap。memcached cas命令用于设置自上次获取以来未更新的数据。如果该键在 memcached 中不存在,则返回not_found。
prepend 命令的基本语法格式如下:
prepend key flags exptime bytes [noreply]
value
语法中的关键字如下所述
命令的输出如下所示 -
stored
要在 memcached 中执行 cas 命令,需要从 memcached gets 命令中获取 cas 令牌。
cas tp 0 900 9
error
cas tp 0 900 9 2
memcached
set tp 0 900 9
memcached
stored
gets tp
value tp 0 9 1
memcached
end
cas tp 0 900 5 2
redis
exists
cas tp 0 900 5 1
redis
stored
get tp
value tp 0 5
redis
end
要从 memcached 服务器获取 cas 数据,您需要使用 memcached gets方法
import net.spy.memcached.memcachedclient;
public class memcachedjava {
public static void main(string[] args) {
// 连接 memcached 服务
memcachedclient mcc = new memcachedclient(new
inetsocketaddress("127.0.0.1", 11211));
system.out.println("connection to server successful");
system.out.println("set status:" mcc.set("jiyik", 900, "memcached").isdone());
// 从缓存中获取 cas token
long casttoken = mcc.gets("tutorialspoint").cas;
system.out.println("cas token:" casttoken);
// 设置新数据
system.out.println("now set new data:" mcc.cas("jiyik",casttoken, 900, "redis"));
system.out.println("get from cache:" mcc.get("jiyik"));
}
}
在编译和执行程序时,输出以下结果:
connection to server successful
set status:true
cas token:3
now set new data:ok
get from cache:redis