Memcached - Comando CAS

CAS sta per Check-And-Set o Compare-and-Swap. MemcachedCAScomando viene utilizzato per impostare i dati se non vengono aggiornati dall'ultimo recupero. Se la chiave non esiste in Memcached, ritornaNOT_FOUND.

Sintassi

La sintassi di base di Memcached CAS il comando è come mostrato di seguito -

set key flags exptime bytes unique_cas_key [noreply]
value

Le parole chiave nella sintassi sono le seguenti:

  • key - È il nome della chiave con cui i dati vengono memorizzati e recuperati da Memcached.

  • flags - È l'intero senza segno a 32 bit che il server memorizza con i dati forniti dall'utente e restituisce insieme ai dati quando l'elemento viene recuperato.

  • exptime- È il tempo di scadenza in secondi. 0 significa nessun ritardo. Se exptime è superiore a 30 giorni, Memcached lo utilizza come un timestamp UNIX per la scadenza.

  • bytes- È il numero di byte nel blocco dati che deve essere memorizzato. Questa è la lunghezza dei dati che devono essere archiviati in Memcached.

  • unique_cas_key - È la chiave univoca ottenuta dal comando gets.

  • noreply (optional) - È un parametro che informa il server di non inviare alcuna risposta.

  • value- Sono i dati che devono essere archiviati. I dati devono essere passati su una nuova riga dopo aver eseguito il comando con le opzioni precedenti.

Produzione

L'output del comando è come mostrato di seguito:

STORED
  • STORED indica il successo.

  • ERROR indica un errore durante il salvataggio dei dati o una sintassi errata.

  • EXISTS indica che qualcuno ha modificato i dati CAS dall'ultimo recupero.

  • NOT_FOUND indica che la chiave non esiste nel server Memcached.

Esempio

Per eseguire un comando CAS in Memcached, è necessario ottenere un token CAS dal comando Get di 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

CAS utilizzando l'applicazione Java

Per ottenere dati CAS da un server Memcached, è necessario utilizzare Memcached gets metodo.

Esempio

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"));
   }
}

Produzione

Durante la compilazione e l'esecuzione del programma, puoi vedere il seguente output:

Connection to server successful
set status:true
Cas token:3
Now set new data:OK
Get from Cache:redis