summaryrefslogtreecommitdiffstats
path: root/docs/manual/socache.xml.fr
blob: d377228ecb07fffe71b14dd5e9cc7f32db0b6201 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?xml version="1.0" encoding="ISO-8859-1" ?>
<!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
<?xml-stylesheet type="text/xsl" href="./style/manual.fr.xsl"?>

<!-- English Revision : 1305167 -->
<!-- French translation : Lucien GENTIS -->
<!-- Reviewed by : Vincent Deffontaines -->

<!--
 Licensed to the Apache Software Foundation (ASF) under one or more
 contributor license agreements.  See the NOTICE file distributed with
 this work for additional information regarding copyright ownership.
 The ASF licenses this file to You under the Apache License, Version 2.0
 (the "License"); you may not use this file except in compliance with
 the License.  You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
-->

<manualpage metafile="socache.xml.meta">

  <title>Le cache des objets partag&eacute;s du serveur HTTP Apache</title>

  <summary>
    <p>Le cache des objets partag&eacute;s est un concept de partage de donn&eacute;es
    de base entre tous les processus d'un serveur, sans se pr&eacute;occuper du
    <a href="mpm.html">mod&egrave;le de threads et de processus</a>. On
    l'utilise lorsque les avantages apport&eacute;s par le partage de donn&eacute;es
    entre processus contrebalance la perte de performances cons&eacute;cutive &agrave;
    la communication interprocessus.</p>
  </summary>

  <section id="providers">
    <title>Fournisseurs du cache d'objets partag&eacute;s</title>
    <p>Le cache d'objets partag&eacute;s en tant que tel est une abstraction.
    Il est impl&eacute;ment&eacute; par quatre modules diff&eacute;rents. Pour pouvoir
    utiliser le cache, un ou plusieurs de ces modules doivent &ecirc;tre
    pr&eacute;sents et configur&eacute;s.</p>
    <p>Le seul &eacute;l&eacute;ment de configuration consiste &agrave; d&eacute;finir le
    fournisseur de cache &agrave; utiliser. Ceci est de la responsabilit&eacute; des
    modules qui utilisent le cache, et pour cela, ils activent la
    s&eacute;lection via des directives telles que <directive
    module="mod_cache_socache">CacheSocache</directive>, <directive
    module="mod_authn_socache">AuthnCacheSOCache</directive>, <directive
    module="mod_ssl">SSLSessionCache</directive>, et <directive
    module="mod_ssl">SSLStaplingCache</directive>.</p>
    <p>Les fournisseurs actuellement disponibles sont :</p>
    <dl>
    <dt>"dbm" (<module>mod_socache_dbm</module>)</dt>
    <dd>Celui-ci utilise un fichier de hashage DBM. Le choix de la
    DBM sous-jacente peut &ecirc;tre configurable si la version
    d'APR install&eacute;e supporte de multiples impl&eacute;mentations de DBM.</dd>
    <dt>"dc" (<module>mod_socache_dc</module>)</dt>
    <dd>Celui-ci utilise les biblioth&egrave;ques de mise en cache de sessions
    distribu&eacute;es <a href="http://www.distcache.org/">distcache</a>.</dd>
    <dt>"memcache" (<module>mod_socache_memcache</module>)</dt>
    <dd>Celui-ci utilise le syst&egrave;me &agrave; hautes performances de mise en
    cache d'objets de m&eacute;moire distribu&eacute;e <a
    href="http://memcached.org/">memcached</a>.</dd>
    <dt>"shmcb" (<module>mod_socache_shmcb</module>)</dt>
    <dd>Celui-ci utilise un tampon cyclique &agrave; hautes performances au
    sein d'un segment de m&eacute;moire partag&eacute;e.</dd>
    </dl>

    <p>L'API fournit les fonctions suivantes :</p>

    <dl>
      <dt>const char *create(ap_socache_instance_t **instance, const char *arg,
                          apr_pool_t *tmp, apr_pool_t *p);</dt>
      <dd>Cette fonction permet de cr&eacute;er un cache de session bas&eacute; sur
      la cha&icirc;ne de configuration sp&eacute;cifi&eacute;e. Le pointeur d'instance
      renvoy&eacute; dans le param&egrave;tre instance sera pass&eacute; comme premier
      argument des invocations subs&eacute;quentes.</dd>

      <dt>apr_status_t init(ap_socache_instance_t *instance, const char *cname,
                         const struct ap_socache_hints *hints,
                         server_rec *s, apr_pool_t *pool)</dt>
      <dd>Cette fonction permet d'initialiser le cache. L'argument cname
      doit avoir une longueur maximale de 16 caract&egrave;res et permet
      d'identifier de mani&egrave;re unique l'utilisateur du cache au sein du
      serveur ; il est recommand&eacute; d'utiliser le nom du module, par
      exemple "mod_ssl-sess". Comme cette cha&icirc;ne peut &ecirc;tre utilis&eacute;e au
      sein d'un syst&egrave;me de fichiers, il est conseill&eacute; de n'utiliser que
      des caract&egrave;res alphanum&eacute;riques [a-z0-9_-]. Si l'argument hints
      n'est pas &eacute;gal &agrave; NULL, il fournit un ensemble d'indications au
      fournisseur. La valeur retourn&eacute;e est le code d'erreur APR.</dd>

      <dt>void destroy(ap_socache_instance_t *instance, server_rec *s)</dt>
      <dd>Cette fonction permet de d&eacute;truire l'instance de cache
      sp&eacute;cifi&eacute;e.</dd>

      <dt>apr_status_t store(ap_socache_instance_t *instance, server_rec *s,
                          const unsigned char *id, unsigned int idlen,
                          apr_time_t expiry,
                          unsigned char *data, unsigned int datalen,
                          apr_pool_t *pool)</dt>
      <dd>Cette fonction permet de stocker un objet dans une instance de
      cache.</dd>

      <dt>apr_status_t retrieve(ap_socache_instance_t *instance, server_rec *s,
                             const unsigned char *id, unsigned int idlen,
                             unsigned char *data, unsigned int *datalen,
                             apr_pool_t *pool)</dt>
      <dd>Cette fonction permet d'extraire un objet du cache.</dd>

      <dt>apr_status_t remove(ap_socache_instance_t *instance, server_rec *s,
                           const unsigned char *id, unsigned int idlen,
                           apr_pool_t *pool)</dt>
      <dd>Supprime un objet du cache.</dd>

      <dt>void status(ap_socache_instance_t *instance, request_rec *r, int flags)</dt>
      <dd>Descend le d&eacute;tail d'une instance de cache &agrave; destination de mod_status.</dd>

      <dt>apr_status_t iterate(ap_socache_instance_t *instance, server_rec *s,
                            void *userctx, ap_socache_iterator_t *iterator,
                            apr_pool_t *pool)</dt>
      <dd>Descend tous les objets en cache &agrave; destination d'une fonction <code>iterator callback</code>.</dd>
    </dl>

  </section>

</manualpage>