Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 26 Apr 2004 23:58:21 +0200
From:      Ivan Voras <ivoras@fer.hr>
To:        current@freebsd.org
Subject:   Dummynet low bandwidth simulation
Message-ID:  <408D85FD.10809@fer.hr>

next in thread | raw e-mail | index | archive | help
I'm trying to see how a web server performes when "attacked" by many low 
bandwith connections, and my idea is to use dummynet to simulate such 
conditions from a single client computer on the same (100Mbps) LAN. I've 
created a pipe:

ipfw pipe 1 config bw 56Kbit/s delay 250 queue 20 buckets 1024 mask all

My rules are:

ipfw pipe 1 tcp from me to webserver dst-port 80
ipfw pipe 1 tcp from webserver 80 to me

When I start the benchmark program (siege) with relatively low 
concurrency (50 clients), everything works as expected, but after 
increasing to 100+ simultaneous requests, I start getting huge amounts 
of "read error: Connection reset by peer" and "broken pipe" messages. 
During that time the load on the web server is low (plenty of idle time 
and memory).

Without traffic shaping, the server handles 250-300 concurrent requests 
without problems in the same setup.

I've tried changing the queue and bucket size (and adding 'noerror'), 
with no results. Eliminating latency (delay 0) "fixes" the problem, but 
it's not meaningfull that way.

Am I missing something?

-- 
C isn't that hard: void (*(*f[])())() defines f as an array of
unspecified size, of pointers to functions that return pointers to
functions that return void.



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?408D85FD.10809>