ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/cvsroot/Coro/myhttpd/access.pl
(Generate patch)

Comparing cvsroot/Coro/myhttpd/access.pl (file contents):
Revision 1.21 by root, Mon Dec 3 05:52:37 2001 UTC vs.
Revision 1.27 by root, Wed Dec 5 02:02:23 2001 UTC

1package transferqueue; 1package transferqueue;
2
3my @reserve = (
4 [ 1_200_000, 2],
5 [ 8_000_000, 1],
6 [ 75_000_000, 1],
7);
2 8
3sub new { 9sub new {
4 my $class = shift; 10 my $class = shift;
5 bless { 11 my $self = bless {
6 slots => $_[0], 12 slots => $_[0],
7 lastspb => 0, 13 lastspb => 0,
8 avgspb => 0, 14 avgspb => 0,
9 }, $class; 15 }, $class;
16 $self->{reschedule} = Event->timer(
17 after => 10,
18 interval => 3,
19 cb => sub { $self->wake_next },
20 );
21 $self;
10} 22}
11 23
12sub start_transfer { 24sub start_transfer {
13 my $self = shift; 25 my $self = shift;
14 my $size = $_[0]; 26 my $size = $_[0];
15 27
16 my $transfer = bless { 28 my $transfer = bless {
17 queue => $self, 29 queue => $self,
18 time => $::NOW, 30 time => $::NOW,
19 size => $size, 31 size => $size,
20 coro => $Coro::current, 32 coro => $Coro::current,
33 started => 0,
21 }, transfer::; 34 }, transfer::;
22 35
23 push @{$self->{wait}}, $transfer; 36 push @{$self->{wait}}, $transfer;
24 Scalar::Util::weaken($self->{wait}[-1]);
25 37
26 $self->wake_next; 38 $self->wake_next;
27 39
28 $trans; 40 $transfer;
29}
30
31sub wake_next {
32 my $self = shift;
33
34 $self->sort;
35
36 while($self->{slots} && @{$self->{wait}}) {
37 my $transfer = shift @{$self->{wait}};
38 if ($transfer) {
39 $self->{lastspb} = $transfer->{spb};
40 $self->{avgspb} ||= $transfer->{spb};
41 $self->{avgspb} = $self->{avgspb} * 0.95 + $transfer->{spb} * 0.05;
42 $transfer->wake;
43 last;
44 }
45 }
46} 41}
47 42
48sub sort { 43sub sort {
49 my @queue = grep $_, @{$_[0]{wait}}; 44 my @queue = grep $_, @{$_[0]{wait}};
50 45
51 $_->{spb} = ($::NOW-$_->{time}) / ($_->{size} || 1) for @queue; 46 $_->{spb} = ($::NOW-$_->{time}) / ($_->{size} || 1) for @queue;
52 47
53 $_[0]{wait} = [sort { $b->{spb} <=> $a->{spb} } @queue]; 48 $_[0]{wait} = [sort { $b->{spb} <=> $a->{spb} } @queue];
49
50 Scalar::Util::weaken $_ for @{$_[0]{wait}};
51}
52
53sub wake_next {
54 my $self = shift;
55
56 $self->sort;
57
58 while (@{$self->{wait}}) {
59 my $size = $self->{wait}[0]{size};
60 my $min = 0;
61 for (@reserve) {
62 last if $size <= $_->[0];
63 $min += $_->[1];
64 }
65 last unless $self->{slots} > $min;
66 my $transfer = shift @{$self->{wait}};
67 $self->{lastspb} = $transfer->{spb};
68 $self->{avgspb} = $self->{avgspb} * 0.99 + $transfer->{spb} * 0.01;
69 $self->{started}++;
70 $transfer->wake;
71 last;
72 }
54} 73}
55 74
56sub waiters { 75sub waiters {
57 $_[0]->sort; 76 $_[0]->sort;
58 @{$_[0]{wait}}; 77 @{$_[0]{wait}};
78}
79
80sub DESTROY {
81 my $self = shift;
82
83 $self->{reschedule}->cancel;
59} 84}
60 85
61package transfer; 86package transfer;
62 87
63use Coro::Timer (); 88use Coro::Timer ();

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines