22
0
Fork 0
wiki/HowtoMemcached.md

224 lines
5.5 KiB
Markdown
Raw Normal View History

2017-02-18 02:14:46 +01:00
---
categories: web
title: Howto Memcached
...
2016-12-29 11:25:39 +01:00
2017-02-18 02:15:11 +01:00
* Documentation : <https://github.com/memcached/memcached/wiki>
2016-12-29 11:25:39 +01:00
2017-02-18 02:14:46 +01:00
[Memcached](http://memcached.org/) est un serveur noSQL clé-valeur non persistent (il stocke tout en mémoire, et toutes les données sont donc perdues après un redémarrage). Son utilisation typique est de mettre en cache des résultats issus de base de données, des réponses d'API, des rendus de pages, etc.
2016-12-29 11:25:39 +01:00
2017-02-18 02:14:46 +01:00
## Installation
2016-12-29 11:25:39 +01:00
~~~
2017-02-17 16:52:05 +01:00
# apt install memcached
2016-12-29 11:25:39 +01:00
~~~
2018-11-21 10:25:39 +01:00
Pour utiliser Memcached avec PHP / Ruby / Python :
2016-12-29 11:25:39 +01:00
~~~
2017-02-18 02:14:46 +01:00
# apt install php5-memcache php5-memcached ruby-remcached python-pymemcache
2016-12-29 11:25:39 +01:00
~~~
## Configuration
2017-02-18 02:14:46 +01:00
La configuration se passe dans le fichier `memcached.conf` :
2016-12-29 11:25:39 +01:00
~~~
-d
# Mode verbose (pour du debug)
logfile /var/log/memcached.log
-v
# -vv
# Taille mémoire (en Mo)
-m 64
# Adresses d'écoute (à supprimer pour ouvrir de partout)
-l 127.0.0.1
-p 11211
-u nobody
# Nombre max de connexions
-c 1024
~~~
## Exemple de script en PHP
<http://www.php.net/manual/en/book.memcache.php>
~~~
<?php
$memcache = memcache_connect("localhost", 11213);
$myValue = $memcache->get('my_value');
if ($myValue == FALSE) {
echo 'Tha value is not in memcache!';
// Adding the value in memcache for 60s
$memcache->add('my_value', "Hello World!", false, 60);
} else {
echo 'The value is in memcache and is: ' . $myValue . '';
}
?>
~~~
## Test en telnet
~~~
$ telnet localhost 11211
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
get foo
VALUE foo 0 2
hi
END
stats
STAT pid 8861
(etc)
~~~
2017-02-19 16:01:02 +01:00
## Administration
Un outil d'administration pratique est [phpmemcacheadmin](https://github.com/elijaa/phpmemcacheadmin)
2020-06-03 05:46:25 +02:00
Afficher la liste des clés avec memcdump (fourni via le paquet libmemcached-tools) :
~~~
$ memcdump --servers=localhost
~~~
2016-12-29 11:25:39 +01:00
## Sessions PHP avec Memcached
2017-02-19 16:01:02 +01:00
_Memcached_ peut notamment être utilisé pour stocker les sessions PHP. Par exemple :
2016-12-29 11:25:39 +01:00
~~~
session.save_handler = memcached
session.save_path = "127.0.0.1:11211/"
~~~
2017-11-30 11:19:37 +01:00
...mais les [développeurs de Memcached le déconseillent](http://dormando.livejournal.com/495593.html) : en effet, _Memcached_ est fait pour du cache et non du stockage.
2016-12-29 11:25:39 +01:00
2017-02-18 02:31:07 +01:00
## Instances
2016-12-29 11:25:39 +01:00
2017-02-18 02:31:07 +01:00
Si besoin, plusieurs instances de _Memcached_ peuvent être lancées sur le serveur, sur des ports TCP différents.
2016-12-29 11:25:39 +01:00
2017-02-19 15:48:40 +01:00
On utilise [systemd](HowtoSystemd) pour gérer les instances, il faut créer un template `/etc/systemd/system/memcached@.service` :
2017-01-03 11:20:35 +01:00
~~~{.ini}
2016-12-29 11:25:39 +01:00
[Unit]
Description=memcached daemon
After=network.target
[Service]
ExecStart=/usr/share/memcached/scripts/systemd-memcached-wrapper /etc/%p_%i.conf
[Install]
WantedBy=multi-user.target
~~~
2017-02-19 15:48:40 +01:00
Ne plus démarrer le service _Memcached_ par défaut dans le target multi-user (~ runlevel 3) :
2017-01-03 11:20:35 +01:00
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
# rm /etc/systemd/system/multi-user.target.wants/memcached.service
2016-12-29 11:25:39 +01:00
~~~
2017-02-18 02:31:07 +01:00
Ensuite pour chaque instance avec un fichier de configuration `/etc/memcached_$nominstance.conf` et un lien symbolique vers le template dans le target multi-user :
2017-01-03 11:20:35 +01:00
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
# cd /etc/systemd/system/multi-user.target.wants/
# ln -s /etc/systemd/system/memcached@.service memcached@$nominstance.service
2016-12-29 11:25:39 +01:00
~~~
2017-02-18 02:31:07 +01:00
Le fichier `/etc/memcached_$nominstance.conf` doit être dupliqué en prenant soin d'adapter les options utiles comme _logfile_ et _-p_.
2016-12-29 11:25:39 +01:00
Puis
2017-01-03 11:20:35 +01:00
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
# systemctl daemon-reload
2016-12-29 11:25:39 +01:00
~~~
On peut ensuite manipuler chaque instance avec systemctl, par exemple :
2017-01-03 11:20:35 +01:00
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
# systemctl <start|stop|restart> memcached@$nominstance
2016-12-29 11:25:39 +01:00
~~~
## Réplication
2017-02-19 15:56:44 +01:00
_Memcached_ n'intègre pas de fonction de réplication/sharding/clustering. Un ancien patch existe pour une réplication master-master : [Repcached](http://repcached.lab.klab.org/) mais c'est ancien et non maintenu : nous déconseillons de l'utiliser en production.
2017-02-18 02:31:07 +01:00
2016-12-29 11:25:39 +01:00
## Monitoring
~~~
$ telnet localhost 11211
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
stats
STAT pid 11575
STAT uptime 417529
STAT time 1339577389
STAT version 1.2.2
STAT pointer_size 64
STAT rusage_user 246.070000
STAT rusage_system 849.540000
STAT curr_items 91905
STAT total_items 15555673
STAT bytes 360080271
STAT curr_connections 33
STAT total_connections 7626105
STAT connection_structures 376
STAT cmd_get 8342525
STAT cmd_set 16858359
STAT get_hits 1700473
STAT get_misses 6642052
STAT evictions 412025
STAT bytes_read 39016879520
STAT bytes_written 3810238557
STAT limit_maxbytes 402653184
STAT threads 1
~~~
### Nagios
2017-02-18 02:14:46 +01:00
Vérification simple :
~~~
$ /usr/lib/nagios/plugins/check_tcp -H 127.0.0.1 -p 11211
~~~
2016-12-29 11:25:39 +01:00
2017-02-19 15:46:15 +01:00
Vérification plus avancée avec :
~~~
# apt install libcache-memcached-perl
$ wget https://raw.githubusercontent.com/willixix/WL-NagiosPlugins/master/check_memcached.pl
$ perl check_memcached.pl -H 127.0.0.1
MEMCACHE OK: memcached 1.4.21 on 127.0.0.1:11211, up 2 minutes 37 seconds
~~~
2016-12-29 11:25:39 +01:00
### Munin
2017-02-19 15:46:15 +01:00
Le plugin Munin pour _Memcached_ est fourni en standard :
2016-12-29 11:25:39 +01:00
~~~
2017-02-19 15:46:15 +01:00
# apt install munin-plugins-extra libcache-memcached-perl
2017-01-03 11:20:35 +01:00
# cd /etc/munin/plugins
2017-02-19 15:46:15 +01:00
# ln -s /usr/share/munin/plugins/memcached_ memcached_bytes
# ln -s /usr/share/munin/plugins/memcached_ memcached_counters
# ln -s /usr/share/munin/plugins/memcached_ memcached_rates
2017-01-03 11:20:35 +01:00
# /etc/init.d/munin-node restart
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
On peut ensuite tester le plugin :
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
# munin-run memcached_bytes
# munin-run memcached_counters
# munin-run memcached_rates
2016-12-29 11:25:39 +01:00
~~~
Des plugins pour Munin existent pour relever diverses informations sur l'utilisation de memcache, comme la mémoire utilisée, le nombre et type de requêtes faites, le nombre de clés dans la base, etc…
Un plugin intéressant et assez complet : <https://github.com/mhwest13/Memcached-Munin-Plugin>