mirror of
https://github.com/apache/httpd.git
synced 2025-11-02 06:53:27 +03:00
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1780462 13f79535-47bb-0310-9956-ffa450edef68
264 lines
13 KiB
Plaintext
264 lines
13 KiB
Plaintext
<?xml version="1.0" encoding="ISO-8859-1"?>
|
||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
|
||
<html xmlns="http://www.w3.org/1999/xhtml" lang="fr" xml:lang="fr"><head>
|
||
<meta content="text/html; charset=ISO-8859-1" http-equiv="Content-Type" />
|
||
<!--
|
||
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
|
||
This file is generated from xml source: DO NOT EDIT
|
||
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
|
||
-->
|
||
<title>mod_lbmethod_byrequests - Serveur Apache HTTP Version 2.5</title>
|
||
<link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
|
||
<link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
|
||
<link href="../style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" /><link rel="stylesheet" type="text/css" href="../style/css/prettify.css" />
|
||
<script src="../style/scripts/prettify.min.js" type="text/javascript">
|
||
</script>
|
||
|
||
<link href="../images/favicon.ico" rel="shortcut icon" /></head>
|
||
<body>
|
||
<div id="page-header">
|
||
<p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/quickreference.html">Directives</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">Glossaire</a> | <a href="../sitemap.html">Plan du site</a></p>
|
||
<p class="apache">Serveur Apache HTTP Version 2.5</p>
|
||
<img alt="" src="../images/feather.png" /></div>
|
||
<div class="up"><a href="./"><img title="<-" alt="<-" src="../images/left.gif" /></a></div>
|
||
<div id="path">
|
||
<a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">Serveur HTTP</a> > <a href="http://httpd.apache.org/docs/">Documentation</a> > <a href="../">Version 2.5</a> > <a href="./">Modules</a></div>
|
||
<div id="page-content">
|
||
<div id="preamble"><h1>Module Apache mod_lbmethod_byrequests</h1>
|
||
<div class="toplang">
|
||
<p><span>Langues Disponibles: </span><a href="../en/mod/mod_lbmethod_byrequests.html" hreflang="en" rel="alternate" title="English"> en </a> |
|
||
<a href="../fr/mod/mod_lbmethod_byrequests.html" title="Fran<61>ais"> fr </a></p>
|
||
</div>
|
||
<table class="module"><tr><th><a href="module-dict.html#Description">Description:</a></th><td>Algorithme de planification avec r<>partition de charge du
|
||
traitement des requ<71>tes pour le module
|
||
<code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code></td></tr>
|
||
<tr><th><a href="module-dict.html#Status">Statut:</a></th><td>Extension</td></tr>
|
||
<tr><th><a href="module-dict.html#ModuleIdentifier">Identificateur<75>de<64>Module:</a></th><td>lbmethod_byrequests_module</td></tr>
|
||
<tr><th><a href="module-dict.html#SourceFile">Fichier<65>Source:</a></th><td>mod_lbmethod_byrequests.c</td></tr>
|
||
<tr><th><a href="module-dict.html#Compatibility">Compatibilit<69>:</a></th><td>Dissoci<63> de <code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code> dans la
|
||
version 2.3</td></tr></table>
|
||
<h3>Sommaire</h3>
|
||
|
||
<p>Ce module ne fournit pas lui-m<>me de directive de configuration. Il
|
||
n<EFBFBD>cessite les services de <code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code>, et
|
||
fournit la m<>thode de r<>partition de charge <code>byrequests</code>.</p>
|
||
</div>
|
||
<div id="quickview"><h3>Sujets</h3>
|
||
<ul id="topics">
|
||
<li><img alt="" src="../images/down.gif" /> <a href="#requests">Algorithme d'attribution des requ<71>tes</a></li>
|
||
</ul><h3 class="directives">Directives</h3>
|
||
<p>Ce module ne fournit aucune directive.</p>
|
||
<h3>Traitement des bugs</h3><ul class="seealso"><li><a href="https://www.apache.org/dist/httpd/CHANGES_2.4">Journal des modifications de httpd</a></li><li><a href="https://bz.apache.org/bugzilla/buglist.cgi?bug_status=__open__&list_id=144532&product=Apache%20httpd-2&query_format=specific&order=changeddate%20DESC%2Cpriority%2Cbug_severity&component=mod_lbmethod_byrequests">Probl<62>mes connus</a></li><li><a href="https://bz.apache.org/bugzilla/enter_bug.cgi?product=Apache%20httpd-2&component=mod_lbmethod_byrequests">Signaler un bug</a></li></ul><h3>Voir aussi</h3>
|
||
<ul class="seealso">
|
||
<li><code class="module"><a href="../mod/mod_proxy.html">mod_proxy</a></code></li>
|
||
<li><code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code></li>
|
||
<li><a href="#comments_section">Commentaires</a></li></ul></div>
|
||
<div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
|
||
<div class="section">
|
||
<h2><a name="requests" id="requests">Algorithme d'attribution des requ<71>tes</a></h2>
|
||
|
||
<p>Activ<69> via <code>lbmethod=byrequests</code>, ce planificateur <20>
|
||
<20>t<EFBFBD> con<6F>u dans le but de distribuer les requ<71>tes <20> tous les
|
||
processus worker afin qu'ils traitent tous le nombre de requ<71>tes
|
||
pour lequel ils ont <20>t<EFBFBD> configur<75>s. Il fonctionne de la mani<6E>re
|
||
suivante : </p>
|
||
|
||
<p><dfn>lbfactor</dfn> correspond <20> la <em>quantit<69> de travail que
|
||
nous attendons de ce processus worker</em>, ou en d'autres termes
|
||
son <em>quota de travail</em>. C'est une valeur normalis<69>e
|
||
repr<70>sentant leur part du travail <20> accomplir.</p>
|
||
|
||
<p><dfn>lbstatus</dfn> repr<70>sente <em>combien il est urgent que
|
||
ce processus worker travaille pour remplir son quota de
|
||
travail</em>.</p>
|
||
|
||
<p>Le <dfn>worker</dfn> est un membre du dispositif de r<>partition
|
||
de charge, en g<>n<EFBFBD>ral un serveur distant traitant un des protocoles
|
||
support<72>s.</p>
|
||
|
||
<p>On distribue <20> chaque processus worker son quota de travail, puis
|
||
on regarde celui qui a le plus besoin de travailler
|
||
(le plus grand lbstatus). Ce processus est alors s<>lectionn<6E> pour
|
||
travailler, et son lbstatus diminu<6E> de l'ensemble des quotas de
|
||
travail que nous avons distribu<62>s <20> tous les processus. La somme de
|
||
tous les lbstatus n'est ainsi pas modifi<66>e, et nous pouvons
|
||
distribuer les requ<71>tes selon nos souhaits.</p>
|
||
|
||
<p>Si certains processus workers sont d<>sactiv<69>s, les autres feront
|
||
l'objet d'une planification normale.</p>
|
||
|
||
<div class="example"><pre><code>for each worker in workers
|
||
worker lbstatus += worker lbfactor
|
||
total factor += worker lbfactor
|
||
if worker lbstatus > candidate lbstatus
|
||
candidate = worker
|
||
|
||
candidate lbstatus -= total factor</code></pre></div>
|
||
|
||
<p>Si un r<>partiteur de charge est configur<75> comme suit :</p>
|
||
|
||
<table><tr><th>worker</th>
|
||
<th class="data">a</th>
|
||
<th class="data">b</th>
|
||
<th class="data">c</th>
|
||
<th class="data">d</th></tr>
|
||
<tr><th>lbfactor</th>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data">0</td>
|
||
<td class="data">0</td>
|
||
<td class="data">0</td>
|
||
<td class="data">0</td></tr>
|
||
</table>
|
||
|
||
<p>Et si <var>b</var> est d<>sactiv<69>, la planification suivante est
|
||
mise en oeuvre :</p>
|
||
|
||
<table><tr><th>worker</th>
|
||
<th class="data">a</th>
|
||
<th class="data">b</th>
|
||
<th class="data">c</th>
|
||
<th class="data">d</th></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>-50</em></td>
|
||
<td class="data">0</td>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data">-25</td>
|
||
<td class="data">0</td>
|
||
<td class="data"><em>-25</em></td>
|
||
<td class="data">50</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data">0</td>
|
||
<td class="data">0</td>
|
||
<td class="data">0</td>
|
||
<td class="data"><em>0</em></td></tr>
|
||
<tr><td class="data" colspan="5">(repeat)</td></tr>
|
||
</table>
|
||
|
||
<p>C'est <20> dire la chronologie suivante : <var>a</var> <var>c</var>
|
||
<var>d</var>
|
||
<var>a</var> <var>c</var> <var>d</var> <var>a</var> <var>c</var>
|
||
<var>d</var> ... Veuillez noter que :</p>
|
||
|
||
<table><tr><th>worker</th>
|
||
<th class="data">a</th>
|
||
<th class="data">b</th>
|
||
<th class="data">c</th>
|
||
<th class="data">d</th></tr>
|
||
<tr><th>lbfactor</th>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td>
|
||
<td class="data">25</td></tr>
|
||
</table>
|
||
|
||
<p>A le m<>me effet que :</p>
|
||
|
||
<table><tr><th>worker</th>
|
||
<th class="data">a</th>
|
||
<th class="data">b</th>
|
||
<th class="data">c</th>
|
||
<th class="data">d</th></tr>
|
||
<tr><th>lbfactor</th>
|
||
<td class="data">1</td>
|
||
<td class="data">1</td>
|
||
<td class="data">1</td>
|
||
<td class="data">1</td></tr>
|
||
</table>
|
||
|
||
<p>Ceci est d<> au fait que toutes les valeurs de <dfn>lbfactor</dfn>
|
||
sont normalis<69>es et <20>valu<6C>es en fonction des autres. Avec :</p>
|
||
|
||
<table><tr><th>worker</th>
|
||
<th class="data">a</th>
|
||
<th class="data">b</th>
|
||
<th class="data">c</th></tr>
|
||
<tr><th>lbfactor</th>
|
||
<td class="data">1</td>
|
||
<td class="data">4</td>
|
||
<td class="data">1</td></tr>
|
||
</table>
|
||
|
||
<p>le processus <var>b</var> va, en moyenne, se voir assigner 4 fois
|
||
plus de requ<71>tes que <var>a</var> et <var>c</var>.</p>
|
||
|
||
<p>La configuration suivante, asym<79>trique, fonctionne comme on peut
|
||
s'y attendre :</p>
|
||
|
||
<table><tr><th>worker</th>
|
||
<th class="data">a</th>
|
||
<th class="data">b</th></tr>
|
||
<tr><th>lbfactor</th>
|
||
<td class="data">70</td>
|
||
<td class="data">30</td></tr>
|
||
<tr><td class="data" colspan="2"> </td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>-30</em></td>
|
||
<td class="data">30</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data">40</td>
|
||
<td class="data"><em>-40</em></td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>10</em></td>
|
||
<td class="data">-10</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>-20</em></td>
|
||
<td class="data">20</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>-50</em></td>
|
||
<td class="data">50</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data">20</td>
|
||
<td class="data"><em>-20</em></td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>-10</em></td>
|
||
<td class="data">10</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>-40</em></td>
|
||
<td class="data">40</td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data">30</td>
|
||
<td class="data"><em>-30</em></td></tr>
|
||
<tr><th>lbstatus</th>
|
||
<td class="data"><em>0</em></td>
|
||
<td class="data">0</td></tr>
|
||
<tr><td class="data" colspan="3">(repeat)</td></tr>
|
||
</table>
|
||
|
||
<p>Apr<70>s 10 distributions, la planification se r<>p<EFBFBD>te et 7
|
||
<var>a</var> sont s<>lectionn<6E>s avec 3 <var>b</var> intercal<61>s.</p>
|
||
</div>
|
||
</div>
|
||
<div class="bottomlang">
|
||
<p><span>Langues Disponibles: </span><a href="../en/mod/mod_lbmethod_byrequests.html" hreflang="en" rel="alternate" title="English"> en </a> |
|
||
<a href="../fr/mod/mod_lbmethod_byrequests.html" title="Fran<61>ais"> fr </a></p>
|
||
</div><div class="top"><a href="#page-header"><img src="../images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">Commentaires</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed again by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Freenode, or sent to our <a href="http://httpd.apache.org/lists.html">mailing lists</a>.</div>
|
||
<script type="text/javascript"><!--//--><![CDATA[//><!--
|
||
var comments_shortname = 'httpd';
|
||
var comments_identifier = 'http://httpd.apache.org/docs/trunk/mod/mod_lbmethod_byrequests.html';
|
||
(function(w, d) {
|
||
if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
|
||
d.write('<div id="comments_thread"><\/div>');
|
||
var s = d.createElement('script');
|
||
s.type = 'text/javascript';
|
||
s.async = true;
|
||
s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
|
||
(d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
|
||
}
|
||
else {
|
||
d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
|
||
}
|
||
})(window, document);
|
||
//--><!]]></script></div><div id="footer">
|
||
<p class="apache">Copyright 2017 The Apache Software Foundation.<br />Autoris<69> sous <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
|
||
<p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/quickreference.html">Directives</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">Glossaire</a> | <a href="../sitemap.html">Plan du site</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!--
|
||
if (typeof(prettyPrint) !== 'undefined') {
|
||
prettyPrint();
|
||
}
|
||
//--><!]]></script>
|
||
</body></html> |