[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] Fix a major load balance bug: we were round-robining in 16 ...
Update of /home2/or/cvsroot/tor/src/or
In directory moria:/home/arma/work/onion/cvs/tor/src/or
Modified Files:
connection.c
Log Message:
Fix a major load balance bug: we were round-robining in 16 KB chunks, and
servers with bandwidthrate of 20 KB, while downloading a 600 KB directory,
would starve their other connections. Now we try to be a bit more fair.
Index: connection.c
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/connection.c,v
retrieving revision 1.435
retrieving revision 1.436
diff -u -p -d -r1.435 -r1.436
--- connection.c 3 Feb 2006 12:26:10 -0000 1.435
+++ connection.c 4 Feb 2006 08:58:51 -0000 1.436
@@ -988,13 +988,18 @@ static int
connection_bucket_read_limit(connection_t *conn)
{
int at_most;
+ int base = connection_speaks_cells(conn) ?
+ CELL_NETWORK_SIZE : RELAY_PAYLOAD_SIZE;
- /* do a rudimentary round-robin so one circuit can't hog a connection */
- if (connection_speaks_cells(conn)) {
- at_most = 32*(CELL_NETWORK_SIZE);
- } else {
- at_most = 32*(RELAY_PAYLOAD_SIZE);
- }
+ /* Do a rudimentary round-robin so one circuit can't hog a connection.
+ * Pick at most 32 cells, at least 4 cells if possible, and if we're in
+ * the middle pick 1/8 of the available bandwidth. */
+ at_most = global_read_bucket / 8;
+ at_most -= (at_most % base); /* round down */
+ if (at_most > 32*base) /* 16 KB */
+ at_most = 32*base;
+ else if (at_most < 4*base) /* 2 KB */
+ at_most = 4*base;
if (at_most > global_read_bucket)
at_most = global_read_bucket;