java memcache cas_Memcached-CAS命令

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

句法

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

set key flags exptime bytes unique_cas_key [noreply]

value

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

密钥-它是密钥的名称,通过它存储和从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数据,您需要使用Memcachedgets方法。

importnet.spy.memcached.MemcachedClient;publicclassMemcachedJava{publicstaticvoidmain(String[]args){// Connecting to Memcached server on localhostMemcachedClientmcc=newMemcachedClient(newInetSocketAddress("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 cachelongcastToken=mcc.gets("tutorialspoint").cas;System.out.println("Cas token:"+castToken);// now set new data in memcached serverSystem.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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值