Memcached替換/Replace數據
Memcached的replace 命令用來替換現有鍵的值。如果該鍵不存在,那麼它輸出NOT_STORED
語法
memcached的replace命令的基本語法如下所示:
replace key flags exptime bytes [noreply] value
以上關鍵字的含義,如下圖所示:
-
key 是通過被存儲在Memcached的數據並從memcached獲取鍵(key)的名稱。
-
flags 是32位無符號整數,該項目被檢索時用的數據(由用戶提供),並沿數據返回服務器存儲。
-
exptime 以秒為過期時間,0表示冇有延遲,如果exptime大於30天,Memcached將使用它作為UNIX時間戳過期。
-
bytes 是在數據塊中,需要被存儲的字節數。基本上,這是一個需要存儲在memcached的數據的長度。
-
noreply (optional) 參數告知服務器不發送回複
-
value 是一個需要存儲的數據。數據需要將通過在新的一行後,執行命令上述選項。
輸出
上述命令的輸出如下所示:
STORED
-
STORED 用來表示成功。
-
NOT_STORED, 如果數據冇有被存儲在memcached。
示例
add key 0 900 9 memcached STORED get key VALUE key 0 9 memcached END replace key 0 900 5 redis get key VALUE key 0 5 redis END
在上麵的例子中,我們已經使用key作為鍵,並存儲memcached在900秒失效時間之前。同樣的鍵替換值為Redis。
使用Java應用程序更換數據
要替換memcached服務器的數據,則需要使用Memcached的replace方法。
示例
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").done); //Get value from cache System.out.println("Get from Cache:"+mcc.get("yiibai")); //now replace the existing data System.out.println("Replace cache:"+mcc.replace("yiibai", 900, "redis").done); //get the updated data System.out.println("Get from Cache:"+mcc.get("yiibai")); } }
輸出
當上述程序編譯和運行,它提供了以下的輸出:
Connection to server successfully set status:true Get from Cache:memcached Replace cache:true Get from Cache:redis