Memcached cas命令
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的數據的長度。
unique_cas_key 從gets命令的獲得唯一鍵。
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
使用Java應用CAS
若要從 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("yiibai", 900, "memcached").isDone());
//Get cas token from cache
long castToken = mcc.gets("yiibai").cas;
System.out.println("Cas token:"+castToken);
// now set new data in memcached server
System.out.println("Now set new data:"+mcc.cas("yiibai", castToken, 900, "redis"));
System.out.println("Get from Cache:"+mcc.get("yiibai"));
}
}
輸出
當上述程序編譯和運行,它提供了以下的輸出:
Connection to server successfully
set status:true
Cas token:3
Now set new data:OK
Get from Cache:redis