Java memcached

De The Linux Craftsman
Révision datée du 21 décembre 2015 à 17:23 par Jc.forton (discussion | contributions) (Page créée avec « =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 d... »)
(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 :

# service memcached start
# chkconfig memcached on

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 PHP

# yum -y install php-pecl-memcache

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 :

$memcache = new Memcache();
$memcache->addserver("192.168.100.110", 11211);

Getter / Setter

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

$key = "compteur";
$value = "1";
$memcache->set($key, $value);

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

$memcache->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
$memcache->increment($key);
# incrémente de 2
$memcache->increment($key, 2);
# décrémente de 1
$memcache->decrement($key);
# décrémente de 2
$memcache->decrement($key, 2);