public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Michael Tremer <michael.tremer@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: Fireperf: first tests an results
Date: Tue, 09 Feb 2021 14:53:11 +0000	[thread overview]
Message-ID: <F539E54D-8C56-43D0-A0CD-A8ED00BE268A@ipfire.org> (raw)
In-Reply-To: <ae6acab7fc942043623641975f573525@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 2704 bytes --]

Hello Daniel,

Thank you very much for testing fireperf and publishing your results. I hope we can collect many more.

> On 9 Feb 2021, at 12:53, daniel.weismueller(a)ipfire.org wrote:
> 
> 
> Hi guys,
> 
> today I installed fireperf on my testing IPFire and my Ubuntu PC.
> 
> server: IPFire Core 154; Intel i7 4790; Intel 82571EB/GB 1GBit Nic
> Client: Ubuntu 20.4; Intel i7 9700; Intel i219-V 1GBit Nic
> 
> Michael and I agreed that one more port should be opened per 5000 expected connection per second (cps)

So far, that is the theory. The rationale behind this is that any connection that is opened by a user space program on Linux has a source port between usually 32768 and 60999:

[root(a)fw01 ~]# sysctl net.ipv4.ip_local_port_range
net.ipv4.ip_local_port_range = 32768	60999

That leaves you with being able to open up to 28231 connections to the same server on the same port. Obviously this is not enough for more than 28k connections and therefore it is necessary to open more listening sockets on the server side. Each will give you another 28231 connections.

However, my system got slower and slower with each connection that was opened - presumably because it takes some time to find a free source port. Therefore I would recommend to open more ports on the server side than strictly necessary.

I have not empirically tested this yet, but about 5000 connections per port intuitively sounds like a good value.

> 
> So here my results:
> 
> 
> Server:
> fireperf -s -P 10000 -p 63000:630010
> 
> Client:
> fireperf -c <IP address> -P 1 -x -p 63000:63010 -> ~5000 cps
> 
> fireperf -c <IP address> -P 10 -x -p 63000:63010 -> ~30000-35000 cps
> 
> fireperf -c <IP address> -P 100 -x -p 63000:63010 -> ~35000-40000 cps
> 
> fireperf -c <IP address> -P 1000 -x -p 63000:63010 -> ~40000-45000 cps
> 
> fireperf -c <IP address> -P 10000 -x -p 63000:63010 -> ~46000-48000 cps
> 
> The cpu utilization was limited to one core and increased in sync with the cps on both sides.
> 
> In my last test, the utilization was about 85-100% on the server and 75-95% on the client.
> 
> In the next days I will test our mini and post the results here.

Yes, I would like to see more performance benchmarks with the LWL appliance range. I have tested them with a couple of pre-releases of fireperf, but they were all in different environments and it would be good to test them all under reproducible conditions.

I would also like to see this tested on weaker hardware. Hopefully we will see any bottlenecks earlier than on 10G sixteen core 19” rack-mountable enterprise system. :) Anyone up for that?

Best,
-Michael

> -
> 
> Daniel
> 


       reply	other threads:[~2021-02-09 14:53 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <ae6acab7fc942043623641975f573525@ipfire.org>
2021-02-09 14:53 ` Michael Tremer [this message]
2021-02-12 12:30 ` Adolf Belka (ipfire-dev)
2021-02-12 12:34   ` Adolf Belka (ipfire-dev)
2021-02-15 16:08     ` Michael Tremer
2022-04-18 11:22       ` Fireperf: Adolf Belka
2021-02-16 11:48   ` Fireperf: first tests an results Michael Tremer
2021-02-16 12:16     ` Adolf Belka (ipfire-dev)
2021-02-16 15:00       ` Michael Tremer
2021-02-17  9:01         ` daniel.weismueller

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=F539E54D-8C56-43D0-A0CD-A8ED00BE268A@ipfire.org \
    --to=michael.tremer@ipfire.org \
    --cc=development@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox