memcached 的 cas 命令用于设置数据,如果自上一次获取没有人更新。如果该键不在memcached中,那么它返回not_found。
memcached的cas命令的基本语法如下所示:
set key flags exptime bytes unique_cas_key [noreply] value
以上关键字的含义,如下图所示:
key 是通过被存储在memcached的数据并从memcached获取键(key)的名称。
flags 是32位无符号整数,该项目被检索时用的数据(由用户提供),并沿数据返回服务器存储。
exptime 以秒过期时间,0表示没有延迟,如果exptime大于30天,memcached将使用它作为unix时间戳过期。
bytes 是在数据块中,需要被存储的字节数。基本上,这是一个需要存储在memcached的数据的长度。
noreply (optional) 参数告知服务器不发送回复
value 是一个需要存储的数据。数据需要将通过在新的一行后,执行命令上述选项。
上述命令的输出如下所示:
stored
stored 表示成功。
error 以表明有问题,同时保存数据或错误的语法。
exists 以表明自上一次获取起已有人修改了cas数据。
exists 以表示该键不存在于memcached服务器。
要运行memcached的cas命令,需要从gets命令得到memcached令牌。
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) {
//connecting to memcached server on localhost
memcachedclient mcc = new memcachedclient(new inetsocketaddress("127.0.0.1", 11211));
system.out.println("connection to server sucessfully");
system.out.println("set status:"+mcc.set("h3", 900, "memcached").isdone());
//get cas token from cache
long casttoken = mcc.gets("h3").cas;
system.out.println("cas token:"+casttoken);
// now set new data in memcached server
system.out.println("now set new data:"+mcc.cas("h3", casttoken, 900, "redis"));
system.out.println("get from cache:"+mcc.get("h3"));
}
}
当上述程序编译和运行,它提供了以下的输出:
connection to server successfully set status:true cas token:3 now set new data:ok get from cache:redis