Memcached - CAS命令

CAS代表Check-And-Set或Compare-And-Swap. Memcached CAS 命令用于设置自上次提取后未更新的数据.如果Memcached中不存在该键,则返回 NOT_FOUND .

语法

Memcached的基本语法 CAS 命令如下所示 :

set key flags exptime bytes unique_cas_key [noreply]
value

语法中的关键字如下所述 :

  • : 它是从Memcached存储和检索数据的密钥的名称.

  • flags : 它是服务器存储的32位无符号整数和用户提供的数据,并在检索项目时返回数据.

  • exptime : 它是以秒为单位的到期时间. 0表示没有延迟.如果exptime超过30天,则Memcached将其用作UNIX时间戳到期.

  • bytes : 它是需要存储的数据块中的字节数.这是需要存储在Memcached中的数据长度.

  • unique_cas_key : 这是获取命令获得的唯一键.

  • noreply(可选) : 这是一个参数,通知服务器不发送任何
    回复.

  • : 它是需要存储的数据.使用上述选项执行命令后,需要在新行上传递数据.

输出

命令的输出如下所示 :

STORED

  • 已存储表示成功.

  • 保存数据或语法错误时出现ERROR 错误.

  • EXISTS 表示有人自上次修改了CAS数据fetch.

  • NOT_FOUND 表示该密钥在Memcached服务器中不存在.

示例

要在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

CAS使用Java应用程序

要从Memcached服务器获取CAS数据,您需要使用Memcached 获取方法.

示例

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 successful");
      System.out.println("set status:"+mcc.set("it1352", 900, "memcached").isDone());

      // Get cas token from cache
      long castToken = mcc.gets("it1352").cas;
      System.out.println("Cas token:"+castToken);

      // now set new data in memcached server
      System.out.println("Now set new data:"+mcc.cas("it1352",
      castToken, 900, "redis"));
      System.out.println("Get from Cache:"+mcc.get("it1352"));
   }
}

输出

在编译和执行程序时,你会到达请参阅以下输出 :

Connection to server successful
set status:true
Cas token:3
Now set new data:OK
Get from Cache:redis