annotate docs/xsls/dump.xsls @ 4621:c90801720a0c
Upstream: smooth weighted round-robin balancing.
For edge case weights like { 5, 1, 1 } we now produce { a, a, b, a, c, a, a }
sequence instead of { c, b, a, a, a, a, a } produced previously.
Algorithm is as follows: on each peer selection we increase current_weight
of each eligible peer by its weight, select peer with greatest current_weight
and reduce its current_weight by total number of weight points distributed
among peers.
In case of { 5, 1, 1 } weights this gives the following sequence of
current_weight's:
a b c
0 0 0 (initial state)
5 1 1 (a selected)
-2 1 1
3 2 2 (a selected)
-4 2 2
1 3 3 (b selected)
1 -4 3
6 -3 4 (a selected)
-1 -3 4
4 -2 5 (c selected)
4 -2 -2
9 -1 -1 (a selected)
2 -1 -1
7 0 0 (a selected)
0 0 0
To preserve weight reduction in case of failures the effective_weight
variable was introduced, which usually matches peer's weight, but is
reduced temporarily on peer failures.
This change also fixes loop with backup servers and proxy_next_upstream
http_404 (ticket #47), and skipping alive upstreams in some cases if there
are multiple dead ones (ticket #64).
author |
Maxim Dounin <mdounin@mdounin.ru> |
date |
Mon, 14 May 2012 09:57:20 +0000 |
parents |
551102312e19 |
children |
2c863b4a8f93 |
rev |
line source |
450
|
1 X:stylesheet {
|
|
2
|
|
3 X:output method="xml"
|
|
4 X:param indent-increment="' '";
|
|
5
|
|
6 X:template noname(indent="'
'") = "*" {
|
|
7 !{$indent}
|
|
8
|
|
9 X:if "name()='xsl:template'" {
|
|
10 !{$indent}
|
|
11 }
|
|
12
|
|
13 X:copy {
|
|
14 X:copy-of "@*"
|
|
15 !!( indent = "concat($indent, $indent-increment)" );
|
|
16 X:if "./* " { !{$indent} }
|
|
17 }
|
|
18 }
|
|
19
|
|
20
|
|
21 X:template = "comment()|processing-instruction()" {
|
|
22 X:copy;
|
|
23 }
|
|
24
|
|
25 <!--
|
|
26 X:template ="text()[normalize-space(.)='']" {}
|
|
27 -->
|
|
28
|
|
29 }
|