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