Memcached CAS 命令

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

语法:

prepend 命令的基本语法格式如下:

prepend key flags exptime bytes [noreply]
value

语法中的关键字如下所述

  • key:键值 key-value 结构中的 key,用于查找缓存值。
  • flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
  • exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
  • bytes:在缓存中存储的字节数
  • unique_cas_key: 它是从 get 命令获取的唯一键。
  • noreply(可选): 该参数告知服务器不需要返回数据
  • value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

命令的输出如下所示 -

STORED
  • 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) {
     
     // 连接 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

查看笔记

扫码一下
查看教程更方便