扫码一下
查看教程更方便
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