Date: Tue, 21 Nov 2006 16:20:17 -0500 From: Phil Rosenthal <pr@isprime.com> To: andre@freebsd.org Cc: freebsd-net@freebsd.org Subject: Re: Automatic TCP send socker buffer sizing Message-ID: <2815E433-4AB2-491D-B62A-D685F6B85F35@isprime.com>
next in thread | raw e-mail | index | archive | help
Hello, I've tested this out and had a few comments. 1) I've seen in production that some sockets get large very quickly during periods of high latency (eg: when sending to a user downloading from a cablemodem and their headend gets temporarily saturated and has large buffers, which raises the RTT under saturation, which increases the bandwidth delay product), but then as there isn't any code to shrink the buffers. This would probably need to be in the timers to notice the case of the sender temporarily stopping sending - eg in a keepalive http socket (a separate, but related issue). 2) In our code, and I believe in other code, we watch the tcp send buffer drain before closing the sockets, which in our implementation works by checking with kqueue how many bytes we can send to that socket. If the buffer size keeps changing, we would now have to call getsockopt() periodically to get the current size, which would obviously have a polling-type performance problem. Is it possible to make a kqueue hook to let us know when the socket buffer size changes? 3) There is a potential for a DoS here as you could have a large number of clients simulate a very large bandwidth delay product (eg: ipfw delay 100,000 ms) and start up a lot of downloads. This could cause your total socket buffers to rapidly grow much larger than normal and eat up all the available kernel memory. Perhaps having another tunable for a soft limit on total socket size past which we get more conservative on buffer sizing, and reduce the size of the largest buffers in exchange for making the smallest buffers larger. 4) What happens if you call setsockopt() to set the size? Perhaps we can have a new setsockopt() flag to disable automatic sizing on a socket if we have a specific size we want a buffer to be and don't want it dynamically sized. After some refining, this does have some very good potential to be very useful for us. -P
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?2815E433-4AB2-491D-B62A-D685F6B85F35>