Memcached - Perintah CAS

CAS adalah singkatan dari Check-And-Set atau Compare-And-Swap. MemcachedCASperintah digunakan untuk menyetel data jika tidak diperbarui sejak pengambilan terakhir. Jika kunci tidak ada di Memcache, maka kunci itu kembaliNOT_FOUND.

Sintaksis

Sintaks dasar Memcached CAS perintah seperti yang ditunjukkan di bawah ini -

set key flags exptime bytes unique_cas_key [noreply]
value

Kata kunci dalam sintaksis dijelaskan di bawah-

  • key - Ini adalah nama kunci yang digunakan untuk menyimpan dan mengambil data dari Memcached.

  • flags - Ini adalah integer 32-bit unsigned yang disimpan server dengan data yang disediakan oleh pengguna, dan dikembalikan bersama dengan data saat item diambil.

  • exptime- Ini adalah waktu kedaluwarsa dalam hitungan detik. 0 berarti tidak ada penundaan. Jika waktu kedaluwarsa lebih dari 30 hari, Memcached menggunakannya sebagai stempel waktu UNIX untuk kedaluwarsa.

  • bytes- Ini adalah jumlah byte dalam blok data yang perlu disimpan. Ini adalah panjang data yang perlu disimpan di Memcache.

  • unique_cas_key - Ini adalah kunci unik yang didapat dari mendapat perintah.

  • noreply (optional) - Ini adalah parameter yang memberi tahu server untuk tidak mengirim balasan apa pun.

  • value- Ini adalah data yang perlu disimpan. Data perlu diteruskan pada baris baru setelah menjalankan perintah dengan opsi di atas.

Keluaran

Output dari perintah tersebut seperti yang ditunjukkan di bawah ini -

STORED
  • STORED menunjukkan kesuksesan.

  • ERROR menunjukkan kesalahan saat menyimpan data atau sintaks yang salah.

  • EXISTS menunjukkan bahwa seseorang telah mengubah data CAS sejak pengambilan terakhir.

  • NOT_FOUND menunjukkan bahwa kunci tidak ada di server Memcached.

Contoh

Untuk menjalankan perintah CAS di Memcached, Anda perlu mendapatkan token CAS dari perintah Memcached gets.

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 Menggunakan Aplikasi Java

Untuk mendapatkan data CAS dari server Memcached, Anda perlu menggunakan Memcached gets metode.

Contoh

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

Keluaran

Saat menyusun dan menjalankan program, Anda bisa melihat output berikut -

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