Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 13 Nov 2012 13:58:07 +0100
From:      Michael Tuexen <tuexen@FreeBSD.org>
To:        Andre Oppermann <oppermann@networx.ch>
Cc:        "freebsd-net@freebsd.org" <freebsd-net@freebsd.org>, Alfred Perlstein <bright@mu.org>
Subject:   Re: auto tuning tcp
Message-ID:  <D5DCDBAE-CCE1-415B-A894-6858307650E6@FreeBSD.org>
In-Reply-To: <50A2407A.5080909@networx.ch>
References:  <50A0A0EF.3020109@mu.org> <50A0A502.1030306@networx.ch> <50A0B8DA.9090409@mu.org> <50A0C0F4.8010706@networx.ch> <EB2C22B5-C18D-4AC2-8694-C5C0D96C07B3@mu.org> <50A13961.1030909@networx.ch> <50A14460.9020504@mu.org> <50A1E2E7.3090705@mu.org> <50A1E47C.1030208@mu.org> <CAGE5yCoj1dL9w-EMMi8iYMTOq9uUUHmFg4rMY7aPneUBHBv67Q@mail.gmail.com> <50A1EC92.9000507@mu.org> <50A1FF80.3040900@networx.ch> <50A20251.7010302@mu.org> <50A203F0.3020803@networx.ch> <50A207CC.3060104@mu.org> <50A2407A.5080909@networx.ch>

next in thread | previous in thread | raw e-mail | index | archive | help

On Nov 13, 2012, at 1:43 PM, Andre Oppermann wrote:

> On 13.11.2012 09:41, Alfred Perlstein wrote:
>> On 11/13/12 12:25 AM, Andre Oppermann wrote:
>>> On 13.11.2012 09:18, Alfred Perlstein wrote:
>>>> On 11/13/12 12:06 AM, Andre Oppermann wrote:
>>>>> On 13.11.2012 07:45, Alfred Perlstein wrote:
>>>>>> If you are concerned about the space/time tradeoff I'm pretty =
happy with making it 1/2, 1/4th,
>>>>>> 1/8th
>>>>>> the size of maxsockets.  (smaller?)
>>>>>>=20
>>>>>> Would that work better?
>>>>>=20
>>>>> I'd go for 1/8 or even 1/16 with a lower bound of 512.  More than
>>>>> that is excessive.
>>>>=20
>>>> I'm OK with 1/8.  All I'm really going for is trying to make it =
somewhat better than 512 when
>>>> un-tuned.
>>> >
>>>>> PS: Please note that my patch for mbuf and maxfiles tuning is not =
yet
>>>>> in HEAD, it's still sitting in my tcp_workqueue branch.  I still =
have
>>>>> to search for derived values that may get totally out of whack =
with
>>>>> the new scaling scheme.
>>>>>=20
>>>> This is cool!  Thank you for the feedback.
>>>>=20
>>>> Would you like me to put this on a user branch somewhere for you to =
merge into your perf branch?
>>>=20
>>> I can put it into my branch and also merge it to HEAD with
>>> a "Submitted by: alfred" line.
>>>=20
>> Thank you, that works.  Note: it's not even compile tested at this =
point.
>>=20
>> I should be able to do so tomorrow.
>>=20
>> Are there other hashes to look at?  I noticed a few more:
>>=20
>> UDBHASHSIZE
>=20
> Even busy UDP servers have only a small number of sockets open.
>=20
>> netinet/tcp_hostcache.c:#define TCP_HOSTCACHE_HASHSIZE          512
>=20
> This is per host, not per connection or socket.  So it should by fine
> and scales independently.
>=20
>> netinet/sctp_constants.h:#define SCTP_TCBHASHSIZE 1024
>> netinet/sctp_constants.h:#define SCTP_PCBHASHSIZE 256
>=20
> Michael has look at that.
I can take a look... I also wanted to make it configurable...

Best regards
Michael
>=20
>> netinet/tcp_syncache.c:#define TCP_SYNCACHE_HASHSIZE            512
>=20
> Again this is not per connection or socket.  It depends on the number
> of concurrent SYN's waiting on SYN/ACK-ACK for a listen socket.  This
> should be fine and it has overflow protection.  If a SYN entry is lost
> it reverts to syncookies.
>=20
>> Any of these look like good targets?  I think most could be looked =
at. I've only glanced.  I can
>> provide deltas.
>=20
> --=20
> Andre
>=20
>=20




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?D5DCDBAE-CCE1-415B-A894-6858307650E6>