📜  Memcached-CAS命令

📅  最后修改于: 2020-11-27 05:43:54             🧑  作者: Mango


CAS代表“检查并设置”或“比较并交换”。如果自上次获取以来未更新数据,则使用Memcached CAS命令设置数据。如果该密钥在Memcached中不存在,则返回NOT_FOUND

句法

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

set key flags exptime bytes unique_cas_key [noreply]
value

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

  • key-它是密钥的名称,通过它存储和从Memcached检索数据。

  • 标志-它是服务器与用户提供的数据一起存储的32位无符号整数,在检索到该项目时将与数据一起返回。

  • exptime-它是到期时间,以秒为单位。 0表示没有延迟。如果exptime超过30天,则Memcached会将其用作UNIX时间戳记进行过期。

  • 字节-这是数据块中需要存储的字节数。这是需要存储在Memcached中的数据的长度。

  • unique_cas_key-这是从gets命令获取的唯一密钥。

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

  • -这是需要存储的数据。使用上述选项执行命令后,需要在新行中传递数据。

输出

命令的输出如下所示-

STORED
  • 存储表示成功。

  • ERROR表示保存数据时出错或语法错误。

  • EXISTS表示自上次获取以来有人修改了CAS数据。

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

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

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

输出

在编译和执行程序时,您将看到以下输出-

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