在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ 數(shù)據(jù)庫/ Memcached cas命令
Memcached刪除/Delete數(shù)據(jù)
Memcached gets命令
Memcached追加/append數(shù)據(jù)
Memcached Stats命令
Memcached stats slabs
Memcached遞增遞減數(shù)據(jù)
Memcached Stats Items
Memcached設(shè)置/set數(shù)據(jù)
Memcached獲取/get數(shù)據(jù)
Memcached stats sizes命令
Memcached清除數(shù)據(jù)
Memcached cas命令
Memcached教程
Memcached添加數(shù)據(jù)
Memcached環(huán)境安裝設(shè)置
Memcached預先添加/Prepend數(shù)據(jù)
Memcached連接
Memcached替換/Replace數(shù)據(jù)

Memcached cas命令

Memcached 的 cas 命令用于設(shè)置數(shù)據(jù),如果自上一次獲取沒有人更新。如果該鍵不在memcached中,那么它返回NOT_FOUND。

語法

memcached的cas命令的基本語法如下所示:

set key flags exptime bytes unique_cas_key [noreply]
value

以上關(guān)鍵字的含義,如下圖所示:

  • key 是通過被存儲在Memcached的數(shù)據(jù)并從memcached獲取鍵(key)的名稱。

  • flags 是32位無符號整數(shù),該項目被檢索時用的數(shù)據(jù)(由用戶提供),并沿數(shù)據(jù)返回服務(wù)器存儲。

  • exptime 以秒過期時間,0表示沒有延遲,如果exptime大于30天,Memcached將使用它作為UNIX時間戳過期。

  • bytes 是在數(shù)據(jù)塊中,需要被存儲的字節(jié)數(shù)?;旧?,這是一個需要存儲在memcached的數(shù)據(jù)的長度。

  • unique_cas_key 從gets命令的獲得唯一鍵。
  • noreply (optional) 參數(shù)告知服務(wù)器不發(fā)送回復

  • value 是一個需要存儲的數(shù)據(jù)。數(shù)據(jù)需要將通過在新的一行后,執(zhí)行命令上述選項。

輸出

上述命令的輸出如下所示:

STORED
  • STORED 表示成功。

  • ERROR 以表明有問題,同時保存數(shù)據(jù)或錯誤的語法。

  • EXISTS 以表明自上一次獲取起已有人修改了CAS數(shù)據(jù)。

  • EXISTS 以表示該鍵不存在于memcached服務(wù)器。

示例

要運行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應(yīng)用CAS

若要從 memcached 服務(wù)器取cas數(shù)據(jù),需要使用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

上一篇:Memcached gets命令下一篇:Memcached教程