Memcached-CASコマンド

CASは、Check-And-SetまたはCompare-And-Swapの略です。MemcachedCAS最後のフェッチ以降にデータが更新されていない場合は、コマンドを使用してデータを設定します。キーがMemcachedに存在しない場合は、NOT_FOUND

構文

Memcachedの基本構文 CAS コマンドは以下のとおりです-

set key flags exptime bytes unique_cas_key [noreply]
value

構文のキーワードは次のとおりです-

  • key −Memcachedからデータを保存および取得するためのキーの名前です。

  • flags −サーバーがユーザーから提供されたデータとともに格納するのは32ビットの符号なし整数であり、アイテムが取得されるとデータとともに返されます。

  • exptime−秒単位の有効期限です。0は遅延がないことを意味します。exptimeが30日を超える場合、Memcachedはそれを有効期限のUNIXタイムスタンプとして使用します。

  • bytes−保存する必要があるのはデータブロックのバイト数です。これは、Memcachedに保存する必要があるデータの長さです。

  • unique_cas_key −これはgetsコマンドから取得する一意のキーです。

  • noreply (optional) −サーバーに応答を送信しないように通知するパラメーターです。

  • 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

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 successful");
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").isDone());

      // Get cas token from cache
      long castToken = mcc.gets("tutorialspoint").cas;
      System.out.println("Cas token:"+castToken);

      // now set new data in memcached server
      System.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