Java memcached

De The Linux Craftsman
Révision datée du 11 février 2018 à 18:57 par Jc.forton (discussion | contributions) (→‎Memcache)
(diff) ← Version précédente | Voir la version actuelle (diff) | Version suivante → (diff)
Aller à la navigation Aller à la recherche

Introduction

Memcached est un système d'usage général servant à gérer la mémoire cache distribuée. Il est souvent utilisé pour augmenter la vitesse de réponse des sites web créés à partir de bases de données. Il gère les données et les objets en RAM de façon à réduire le nombre de fois qu'une même donnée stockée dans un périphérique externe est lue. Il tourne sous Unix, Windows et MacOS et est distribué selon les termes d'une licence libre dite permissive1.

Memcached a été initialement mis au point par Danga Interactive pour LiveJournal. En 2010, il est utilisé par d'autres sites, plusieurs très fréquentés, tels que YouTube, Reddit, Zynga, Facebook et Twitter.

Wikipedia

On peut avoir besoin de Memcache lorsque l'on à besoin de se substituer à la base de données. En effet, il peut être intéressant de faire ce que l'on appel un Mock qui implémente la même interface que le DAO mais qui stocke les objets en mémoire.

Installation

Pour utiliser Memchache, il faut l'installer sur un serveur et pour pouvoir l'utiliser il faut des librairies Java. Vous pouvez tout faire sur la même machine, ou bien déporter le serveur sur une autre machine.

Memcache

# yum -y install memcached

Il faut maintenant démarrer le serveur Memcache et l'enregistrer dans le chargeur de démarrage :

  • CentOS 6 :
# service memcached start
# chkconfig memcached on
  • CentOS 7+ :
# systemctl start memcached.service
# systemctl enable memcached.service

On vérifie le bon fonctionnement:

# netstat -atnp | grep memcached
tcp        0      0 0.0.0.0:11211               0.0.0.0:*                   LISTEN      1466/memcached
tcp        0      0 :::11211                    :::*                        LISTEN      1466/memcached

On n'oublie pas d'ouvrir le pare-feu:

# iptables -I INPUT 2 -p tcp --dport 11211 -j ACCEPT
# service iptables save

Librairies Java

Le JAR à récupérer s'appelle spymemcached et se trouve ici : https://code.google.com/p/spymemcached/downloads/list

Intégrez le au Build Path de votre projet avant de continuer.

Menu add jar to buildpath memcache.png Add memcache client jar.png

Utilisation

Connexion

Tout d'abord, il faut créer la connexion au serveur memcache, dans cette exemple, le serveur possède l'adresse IP 192.168.100.110 :

package fr.tala;

import java.io.IOException;
import java.net.InetSocketAddress;

import net.spy.memcached.MemcachedClient;

public class CacheTest {
   public static void main(String args[]){
      try {
          MemcachedClient mc = new MemcachedClient(new InetSocketAddress("192.168.100.110", 11211));
      } catch (IOException e) {
	   e.printStackTrace();
      }
   }
}

Getter / Setter

On peut ensuite ajouter une variable identifiée grâce à une clé ($key) et une valeur ($value) :

String key = "compteur";
mc.set(key, 0, "0");

Le chiffre entre la clé et la valeur permet de paramétrer la durée de vie de la variable sur le serveur Memcache.

On peut maintenant la récupérer grâce à sa key:

mc.get(key);

Incrément / décrément

On peut utiliser, si la variable est un entier, une méthode qui permettra d'incrémenter ou de décrémenter directement sa valeur sans avoir à la récupérer :

# incrémente de 1
mc.incr(key, 1);
# incrémente de 2
mc.incr(key, 2);
# décrémente de 1
mc.decr(key, 1);
# décrémente de 2
mc.decr(key, 2);

Attention : en Java, vous devez créer la variables comme indiqué dans la partie Getter / Setter. Si vous typez une variable en int avant de l'ajouter avec set, memcache sera incapable de l'incrémenter. Étrange ? Le bug est détaillé ici