Memcached - Panduan Cepat

Memcached adalah sumber terbuka, kinerja tinggi, sistem cache memori terdistribusi yang dimaksudkan untuk mempercepat aplikasi web dinamis dengan mengurangi beban database. Ini adalah kamus nilai kunci dari string, objek, dll., Yang disimpan dalam memori, yang dihasilkan dari panggilan database, panggilan API, atau rendering halaman.

Memcached dikembangkan oleh Brad Fitzpatrick untuk LiveJournal pada tahun 2003. Namun, sekarang digunakan oleh Netlog, Facebook, Flickr, Wikipedia, Twitter, dan YouTube.

Fitur utama Memcached adalah sebagai berikut -

  • Ini open source.

  • Server memcache adalah tabel hash yang besar.

  • Ini secara signifikan mengurangi beban database

  • Ini sangat efisien untuk situs web dengan beban database tinggi.

  • Ini didistribusikan di bawah lisensi Berkeley Software Distribution (BSD).

  • Ini adalah aplikasi klien-server melalui TCP atau UDP.

Memcache tidak -

  • penyimpanan data yang persisten

  • database

  • application-specific

  • cache objek yang besar

  • toleransi kesalahan atau sangat tersedia

Menginstal Memcached di Ubuntu

Untuk menginstal Memcached di Ubuntu, buka terminal dan ketik perintah berikut -

$sudo apt-get update
$sudo apt-get install memcached

Mengonfirmasi Instalasi Memcached

Untuk mengonfirmasi apakah Memcache diinstal atau tidak, Anda perlu menjalankan perintah yang diberikan di bawah ini. Perintah ini menunjukkan bahwa Memcached berjalan di port default11211.

$ps aux | grep memcached

Untuk menjalankan server Memcached pada port yang berbeda, jalankan perintah yang diberikan di bawah ini. Perintah ini memulai server pada port TCP 11111 dan mendengarkan pada port UDP 11111 sebagai proses daemon.

$memcached -p 11111 -U 11111 -u user -d

Anda dapat menjalankan beberapa contoh server Memcached melalui satu instalasi.

Pengaturan Lingkungan Java Memcached

Untuk menggunakan Memcached di program Java Anda, Anda perlu mengunduh spymemcached-2.10.3.jar dan siapkan jar ini ke classpath.

Untuk menyambung ke server Memcached, Anda perlu menggunakan perintah telnet pada nama HOST dan PORT.

Sintaksis

Sintaks dasar dari perintah telnet Memcached adalah seperti yang ditunjukkan di bawah ini -

$telnet HOST PORT

Sini, HOST dan PORT adalah IP mesin dan nomor port masing-masing, tempat server Memcache sedang dieksekusi.

Contoh

Contoh berikut menunjukkan cara menghubungkan ke server Memcached dan menjalankan perintah set dan get sederhana. Asumsikan bahwa server Memcached berjalan pada host 127.0.0.1 dan port 11211.

$telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
// now store some data and get it from memcached server
set tutorialspoint 0 900 9
memcached
STORED
get tutorialspoint
VALUE tutorialspoint 0 9
memcached
END

Koneksi dari Aplikasi Java

Untuk menghubungkan server Memcached dari program java Anda, Anda perlu menambahkan jar Memcached ke jalur kelas Anda seperti yang ditunjukkan pada bab sebelumnya. Asumsikan bahwa server Memcached berjalan pada host 127.0.0.1 dan port 11211. -

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 sucessfully");
      
      //not set data into memcached server
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").done);
      
      //Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:memcached.

Terminal mungkin juga menampilkan beberapa pesan informasional, yang dapat diabaikan.

Memcached set perintah digunakan untuk menetapkan nilai baru ke kunci baru atau yang sudah ada.

Sintaksis

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

set key flags exptime bytes [noreply] 
value

Kata kunci dalam sintaks dijelaskan di bawah ini -

  • 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.

  • 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 ke 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 sintaks yang salah atau kesalahan saat menyimpan data.

Contoh

Dalam contoh berikut, kami menggunakan tutorialspoint sebagai kunci dan menetapkan nilai Memcache di dalamnya dengan waktu kedaluwarsa 900 detik.

set tutorialspoint 0 900 9
memcached
STORED
get tutorialspoint
VALUE tutorialspoint 0 9
Memcached
END

Set Data Menggunakan Aplikasi Java

Untuk mengatur kunci di server Memcached, Anda perlu menggunakan Memcached set 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 sucessfully");
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").done);
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:memcached

Memcached addperintah digunakan untuk menetapkan nilai ke kunci baru. Jika kunci sudah ada, maka keluarannya NOT_STORED.

Sintaksis

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

add key flags exptime bytes [noreply]
value

Kata kunci dalam sintaks dijelaskan di bawah ini -

  • 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.

  • 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 ke baris baru setelah menjalankan perintah dengan opsi di atas.

Keluaran

Output dari perintah tersebut seperti yang ditunjukkan di bawah ini -

STORED
  • STORED menunjukkan kesuksesan.

  • NOT_STORED menunjukkan data tidak disimpan di Memcached.

Contoh

Dalam contoh berikut, kami menggunakan 'key' sebagai kunci dan menambahkan nilai Memcached di dalamnya dengan waktu kedaluwarsa 900 detik.

add key 0 900 9
memcached
STORED
get key
VALUE key 0 9
Memcached
END

Keluaran Kegagalan

add key 0 900 5
redis
NOT_STORED

Tambahkan Data Menggunakan Aplikasi Java

Untuk menambahkan data di server Memcached, Anda perlu menggunakan Memcached add 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("add status:"+mcc.add("tutorialspoint", 900, "redis").done);
      System.out.println("add status:"+mcc.add("tp", 900, "redis").done);
      
      // Get value from cache
      System.out.println("Get from Cache tp:"+mcc.get("tp"));
   }
}

Keluaran

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

Connection to server successful
add status:false
add status:true
Get from Cache tp:redis

Memcached replaceperintah digunakan untuk mengganti nilai kunci yang sudah ada. Jika kunci tidak ada, maka itu memberikan keluaran NOT_STORED.

Sintaksis

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

replace key flags exptime bytes [noreply]
value

Kata kunci dalam sintaks dijelaskan di bawah ini -

  • 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.

  • 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 ke baris baru setelah menjalankan perintah dengan opsi di atas.

Keluaran

Output dari perintah tersebut seperti yang ditunjukkan di bawah ini -

STORED
  • STORED menunjukkan kesuksesan.

  • NOT_STORED menunjukkan data tidak disimpan di Memcached.

Contoh

Dalam contoh berikut, kami menggunakan 'key' sebagai kunci dan menyimpan memcache di dalamnya dengan waktu kedaluwarsa 900 detik. Setelah ini, kunci yang sama diganti dengan nilai 'redis'.

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

Ganti Data Menggunakan Aplikasi Java

Untuk mengganti data di server Memcached, Anda perlu menggunakan Memcached replace 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 sucessfully");
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").done);
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
      
      // now replace the existing data
      System.out.println("Replace cache:"+mcc.replace("tutorialspoint", 900, "redis").done);
      
      // get the updated data
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:memcached
Replace cache:true
Get from Cache:redis

Memcached appendperintah digunakan untuk menambahkan beberapa data dalam kunci yang sudah ada. Data tersebut disimpan setelah data kunci yang ada.

Sintaksis

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

append key flags exptime bytes [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.

  • 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 ke baris baru setelah menjalankan perintah dengan opsi di atas.

Keluaran

Output dari perintah tersebut seperti yang ditunjukkan di bawah ini -

STORED
  • STORED menunjukkan kesuksesan.

  • NOT_STORED menunjukkan kunci tidak ada di server Memcached.

  • CLIENT_ERROR menunjukkan kesalahan.

Contoh

Dalam contoh berikut, kami mencoba menambahkan beberapa data dalam kunci yang tidak ada. Karenanya, Memcached kembaliNOT_STORED. Setelah ini, kami menetapkan satu kunci dan menambahkan data ke dalamnya.

append tutorials 0 900 5
redis
NOT_STORED
set tutorials 0 900 9
memcached
STORED
get tutorials
VALUE tutorials 0 14
memcached
END
append tutorials 0 900 5
redis
STORED
get tutorials
VALUE tutorials 0 14
memcachedredis
END

Menambahkan Data Menggunakan Aplikasi Java

Untuk menambahkan data di server Memcached, Anda perlu menggunakan Memcached append 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 value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
      
      // now append some data into existing key
      System.out.println("Append to cache:"+mcc.append("tutorialspoint", "redis").isDone());
      
      // get the updated key
      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
Get from Cache:memcached
Append to cache:true
Get from Cache:memcachedredis

Memcached prependperintah digunakan untuk menambahkan beberapa data dalam kunci yang sudah ada. Data disimpan sebelum data kunci yang ada.

Sintaksis

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

prepend key flags exptime bytes [noreply]
value

Kata kunci dalam sintaksis dijelaskan di bawah-

  • key - Ini adalah nama kunci yang digunakan untuk menyimpan dan mengambil data di 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.

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

  • 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.

  • NOT_STORED menunjukkan kunci tidak ada di server Memcached.

  • CLIENT_ERROR menunjukkan kesalahan.

Contoh

Dalam contoh berikut, kami menambahkan beberapa data dalam kunci yang tidak ada. Karenanya, Memcached kembaliNOT_STORED. Setelah ini, kami menetapkan satu kunci dan menambahkan data ke dalamnya.

prepend tutorials 0 900 5
redis
NOT_STORED
set tutorials 0 900 9
memcached
STORED
get tutorials
VALUE tutorials 0 14
memcached
END
prepend tutorials 0 900 5
redis
STORED
get tutorials
VALUE tutorials 0 14
redismemcached
END

Tambahkan Data Menggunakan Aplikasi Java

Untuk menambahkan data di server Memcached, Anda perlu menggunakan Memcache prepend 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 value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
      
      // now append some data into existing key
      System.out.println("Prepend to cache:"+mcc.prepend("tutorialspoint", "redis").isDone());
      
      // get the updated key
      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
Get from Cache:memcached
Prepend to cache:true
Get from Cache:redismemcached

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

Memcached getperintah digunakan untuk mendapatkan nilai yang disimpan di kunci. Jika kunci tidak ada di Memcache, maka tidak ada yang dikembalikan.

Sintaksis

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

get key

Contoh

Dalam contoh berikut, kami menggunakan tutorialspoint sebagai kunci dan menyimpan memcache di dalamnya dengan waktu kedaluwarsa 900 detik.

set tutorialspoint 0 900 9
memcached
STORED
get tutorialspoint
VALUE tutorialspoint 0 9
memcached
END

Dapatkan Data Menggunakan Aplikasi Java

Untuk mendapatkan data dari server Memcached, Anda perlu menggunakan Memcached get 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 sucessfully");
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").done);
     
     // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:memcached

Memcached getsperintah digunakan untuk mendapatkan nilai dengan token CAS. Jika kunci tidak ada di Memcache, maka tidak ada yang dikembalikan.

Sintaksis

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

get key

Contoh

set tutorialspoint 0 900 9
memcached
STORED
gets tutorialspoint
VALUE tutorialspoint 0 9 1
memcached
END

Dalam contoh ini, kami menggunakan tutorialspoint sebagai kunci dan menyimpan memcache di dalamnya dengan waktu kedaluwarsa 900 detik.

Dapatkan Data 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 sucessfully");
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").done);
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.gets("tutorialspoint"));
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:{CasValue 2/memcached}

Memcached delete perintah digunakan untuk menghapus kunci yang ada dari server Memcached.

Sintaksis

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

delete key [noreply]

Keluaran

Perintah CAS dapat menghasilkan salah satu dari hasil berikut -

  • DELETED menunjukkan penghapusan yang berhasil.

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

  • NOT_FOUND menunjukkan bahwa kunci tidak ada di server Memcached.

Contoh

Dalam contoh ini, kami menggunakan tutorialspoint sebagai kunci dan menyimpan memcache di dalamnya dengan waktu kedaluwarsa 900 detik. Setelah ini, ini menghapus kunci yang disimpan.

set tutorialspoint 0 900 9
memcached
STORED
get tutorialspoint
VALUE tutorialspoint 0 9
memcached
END
delete tutorialspoint
DELETED
get tutorialspoint
END
delete tutorialspoint
NOT_FOUND

Hapus Data Menggunakan Aplikasi Java

Untuk menghapus data dari server Memcached, Anda perlu menggunakan Memcached delete metode.

Contoh

import java.net.InetSocketAddress;
import java.util.concurrent.Future;

import net.spy.memcached.MemcachedClient;

public class MemcachedJava {
   public static void main(String[] args) {
   
      try{
   
         // Connecting to Memcached server on localhost
         MemcachedClient mcc = new MemcachedClient(new InetSocketAddress("127.0.0.1", 11211));
         System.out.println("Connection to server sucessful.");

         // add data to memcached server
         Future fo = mcc.set("tutorialspoint", 900, "World's largest online tutorials library");

         // print status of set method
         System.out.println("set status:" + fo.get());

         // retrieve and check the value from cache
         System.out.println("tutorialspoint value in cache - " + mcc.get("tutorialspoint"));

         // try to add data with existing key
         Future fo = mcc.delete("tutorialspoint");

         // print status of delete method
         System.out.println("delete status:" + fo.get());

         // retrieve and check the value from cache
         System.out.println("tutorialspoint value in cache - " + mcc.get("codingground"));

         // Shutdowns the memcached client
         mcc.shutdown();
         
      }catch(Exception ex)
         System.out.println(ex.getMessage());
   }
}

Keluaran

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

Connection to server successful
set status:true
tutorialspoint value in cache - World's largest online tutorials library
delete status:true
tutorialspoint value in cache - null

Memcached delete perintah digunakan untuk menghapus kunci yang ada dari server Memcached.

Sintaksis

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

delete key

Jika kunci berhasil dihapus, maka kunci tersebut kembali DIHAPUS. Jika kuncinya tidak ditemukan, maka ia mengembalikan NOT_FOUND, jika tidak ia mengembalikan ERROR.

Contoh

Dalam contoh ini, kami menggunakan tutorialspoint sebagai kunci dan menyimpan memcache di dalamnya dengan waktu kedaluwarsa 900 detik. Setelah ini, ini menghapus kunci yang disimpan.

set tutorialspoint 0 900 9
memcached
STORED
get tutorialspoint
VALUE tutorialspoint 0 9
memcached
END
delete tutorialspoint
DELETED
get tutorialspoint
END
delete tutorialspoint
NOT_FOUND

Hapus Data Menggunakan Aplikasi Java

Untuk menghapus data dari server Memcached, Anda perlu menggunakan Memcached delete 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").done);
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
      
      // delete value from cache
      System.out.println("Delete from Cache:"+mcc.delete("tutorialspoint").isDone());
      
      // check whether value exists or not
      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
Get from Cache:memcached
Delete from Cache:true
Get from Cache:null

Memcached incr dan decrperintah digunakan untuk menambah atau mengurangi nilai numerik dari kunci yang ada. Jika kuncinya tidak ditemukan, maka kunci itu kembaliNOT_FOUND. Jika kuncinya bukan numerik, maka kuncinya akan kembaliCLIENT_ERROR cannot increment or decrement non-numeric value. Jika tidak,ERROR dikembalikan.

Sintaks - incr

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

incr key increment_value

Contoh

Dalam contoh ini, kami menggunakan pengunjung sebagai kunci dan awalnya menetapkan 10 ke dalamnya, kemudian kami menambah pengunjung sebesar 5.

set visitors 0 900 2
10
STORED
get visitors
VALUE visitors 0 2
10
END
incr visitors 5
15
get visitors
VALUE visitors 0 2
15
END

Sintaks - decr

Sintaks dasar Memcached decr perintah seperti yang ditunjukkan di bawah ini

decr key decrement_value

Contoh

set visitors 0 900 2
10
STORED
get visitors
VALUE visitors 0 2
10
END
decr visitors 5
5
get visitors
VALUE visitors 0 1
5
END

Incr / Decr Menggunakan Aplikasi Java

Untuk menambah atau mengurangi data di server Memcached, Anda perlu menggunakan Memcached incr or decr metode masing-masing.

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 sucessfully");
      System.out.println("set status:"+mcc.set("count", 900, "5").isDone());
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("count"));
      
      // now increase the stored value
      System.out.println("Increment value:"+mcc.incr("count", 2));
      
      // now decrease the stored value
      System.out.println("Decrement value:"+mcc.decr("count", 1));
      
      // now get the final stored value
      System.out.println("Get from Cache:"+mcc.get("count"));
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:5
Increment value:7
Decrement value:6
Get from Cache:6

Memcached stats perintah digunakan untuk mengembalikan statistik server seperti PID, versi, koneksi, dll.

Sintaksis

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

stats

Contoh

stats
STAT pid 1162
STAT uptime 5022
STAT time 1415208270
STAT version 1.4.14
STAT libevent 2.0.19-stable
STAT pointer_size 64
STAT rusage_user 0.096006
STAT rusage_system 0.152009
STAT curr_connections 5
STAT total_connections 6

STAT connection_structures 6
STAT reserved_fds 20
STAT cmd_get 6
STAT cmd_set 4
STAT cmd_flush 0
STAT cmd_touch 0
STAT get_hits 4
STAT get_misses 2
STAT delete_misses 1
STAT delete_hits 1

STAT incr_misses 2
STAT incr_hits 1
STAT decr_misses 0
STAT decr_hits 1
STAT cas_misses 0
STAT cas_hits 0
STAT cas_badval 0
STAT touch_hits 0
STAT touch_misses 0
STAT auth_cmds 0

STAT auth_errors 0
STAT bytes_read 262
STAT bytes_written 313
STAT limit_maxbytes 67108864
STAT accepting_conns 1
STAT listen_disabled_num 0
STAT threads 4
STAT conn_yields 0
STAT hash_power_level 16

STAT hash_bytes 524288
STAT hash_is_expanding 0
STAT expired_unfetched 1
STAT evicted_unfetched 0
STAT bytes 142
STAT curr_items 2
STAT total_items 6
STAT evictions 0
STAT reclaimed 1
END

Statistik Menggunakan Aplikasi Java

Untuk mendapatkan statistik dari server Memcached, Anda perlu menggunakan Memcached stats 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("Stats:"+mcc.stats);
   }
}

Keluaran

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

Connection to server successful
Stats:[/127.0.0.1:11211:[delete_hits:0, bytes:71, total_items:4,
rusage_system:0.220013, touch_misses:0, cmd_touch:0, listen_disabled_num:0,
auth_errors:0, evictions:0, version:1.4.14, pointer_size:64, time:1417279366,
incr_hits:1, threads:4, expired_unfetched:0, limit_maxbytes:67108864,
hash_is_expanding:0, bytes_read:170, curr_connections:8, get_misses:1,
reclaimed:0, bytes_written:225, hash_power_level:16, connection_structures:9,
cas_hits:0, delete_misses:0, total_connections:11, rusage_user:0.356022,
cmd_flush:0, libevent:2.0.19-stable, uptime:12015, reserved_fds:20,
touch_hits:0, cas_badval:0, pid:1138, get_hits:2, curr_items:1, cas_misses:0,
accepting_conns:1, evicted_unfetched:0, cmd_get:3, cmd_set:2, auth_cmds:0,
incr_misses:1, hash_bytes:524288, decr_misses:1, decr_hits:1, conn_yields:0]]

Memcached stats items perintah digunakan untuk mendapatkan statistik item seperti jumlah, usia, penggusuran, dll. yang diatur oleh slab ID.

Sintaksis

Sintaks dasar Memcached stats items perintah seperti yang ditunjukkan di bawah ini -

stats items

Contoh

stats items
STAT items:1:number 1
STAT items:1:age 7
STAT items:1:evicted 0
STAT items:1:evicted_nonzero 0
STAT items:1:evicted_time 0
STAT items:1:outofmemory 0
STAT items:1:tailrepairs 0
STAT items:1:reclaimed 0
STAT items:1:expired_unfetched 0
STAT items:1:evicted_unfetched 0
END

Memcached stats slabs Perintah menampilkan statistik lempengan seperti ukuran, penggunaan memori, perintah, jumlah dll yang diatur oleh ID lempengan.

Sintaksis

Sintaks dasar Memcached stats slabs perintah seperti yang ditunjukkan di bawah ini -

stats slabs

Contoh

stats slabs
STAT 1:chunk_size 96
STAT 1:chunks_per_page 10922
STAT 1:total_pages 1
STAT 1:total_chunks 10922
STAT 1:used_chunks 1
STAT 1:free_chunks 10921
STAT 1:free_chunks_end 0
STAT 1:mem_requested 71
STAT 1:get_hits 0
STAT 1:cmd_set 1
STAT 1:delete_hits 0
STAT 1:incr_hits 0
STAT 1:decr_hits 0
STAT 1:cas_hits 0
STAT 1:cas_badval 0
STAT 1:touch_hits 0
STAT active_slabs 1
STAT total_malloced 1048512
END

Memcached stats sizesperintah memberikan informasi tentang ukuran dan jumlah item dari setiap ukuran di dalam cache. Informasi dikembalikan dalam dua kolom. Kolom pertama adalah ukuran item (dibulatkan ke batas 32 byte terdekat), dan kolom kedua adalah jumlah item dengan ukuran tersebut di dalam cache.

Sintaksis

Sintaks dasar Memcached stats sizes perintah seperti yang ditunjukkan di bawah ini -

stats sizes

Contoh

stats sizes
STAT 96 1
END

Statistik ukuran item hanya berguna untuk menentukan ukuran objek yang Anda simpan. Karena alokasi memori sebenarnya hanya relevan dalam hal ukuran potongan dan ukuran halaman, informasi tersebut hanya berguna selama debugging atau sesi diagnostik yang cermat.

Memcached flush_allperintah digunakan untuk menghapus semua data (pasangan nilai kunci) dari server Memcached. Ini menerima parameter opsional yang disebuttime yang menetapkan waktu setelah data Memcache akan dihapus.

Sintaksis

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

flush_all [time] [noreply]

Perintah di atas selalu mengembalikan OK.

Contoh

Dalam contoh berikut, kami menyimpan beberapa data ke server Memcached dan kemudian menghapus semua data.

set tutorialspoint 0 900 9
memcached
STORED
get tutorialspoint
VALUE tutorialspoint 0 9
memcached
END
flush_all
OK
get tutorialspoint
END

Hapus Data Menggunakan Aplikasi Java

Untuk menghapus data dari server Memcached, Anda perlu menggunakan Memcached flush 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 sucessfully");
      System.out.println("set status:"+mcc.set("count", 900, "5").isDone());
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("count"));
     
      // now increase the stored value
      System.out.println("Increment value:"+mcc.incr("count", 2));
     
      // now decrease the stored value
      System.out.println("Decrement value:"+mcc.decr("count", 1));
      
      // now get the final stored value
      System.out.println("Get from Cache:"+mcc.get("count"));
      
      // now clear all this data
      System.out.println("Clear data:"+mcc.flush().isDone());
   }
}

Keluaran

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

Connection to server successfully
set status:true
Get from Cache:5
Increment value:7
Decrement value:6
Get from Cache:6
Clear data:true