Testing ntttcp as an iperf3 alternative in Windows 11 (and Linux)
ntttcp (Windows NT Test TCP) is a network benchmarking utility similar to iperf3 that works in both Windows and Linux written and recommended by Microsoft over iperf3, so we’ll test the alternative in this mini review.
iperf3 is a utility of choice for our reviews of single board computers and mini PCs running either Windows or Linux, but we’ve noticed that while Ethernet (up to 2.5GbE) usually performs just as well in Windows and Linux, WiFi is generally much faster in Ubuntu 22.04 than in Windows 11. So when XDA developers noticed a post by Microsoft saying iperf3 should not be used on Windows 11, it caught my attention.
Microsoft explains iperf3 should not be used in Windows for three main reasons:
The maintainer of iperf – ESnet (Energy Sciences Network) – says “iperf3 is not officially supported on Windows, but iperf2 is. We recommend you use iperf2. Some people are using Cygwin to run iperf3 in Windows, but not all options will work”
iPerf3 is Emulated on Windows – iPerf3 does not make Windows native API calls as it only knows how to make Linux/POSIX calls, and this may impact performance.
I usually download iperf3 3.1.3 for Windows released in 2016, and Microsoft notes the one offered by ESnet (version 3.16) is more recent but still 15 versions behind, so users are not running the latest version of the utilities.
So what’s the alternative for iperf3? Microsoft maintains two:
ntttcp (Windows NT Test TCP) open-source utility for Windows and Linux with a command line similar to iperf3 according to Microsoft in the sense it aims to isolate network stack throughput.
ctsTraffic for Windows-to-Windows testing only, also open-source and maintained on Github. ctsTraffic focuses on end-to-end goodput scenarios.
We can disqualify ctsTraffic immediately here at CNX Software since our tests typically involve a mix of Linux and Windows machines. Microsoft compared iperf3 to ntttcp utilities with high-speed network interfaces (10 GbE+), and the latter reports much higher performance. I only have hardware with 2.5GbE and WiFi 6, but I still wanted to test it, especially to check WiFi. So I decided to give ntttcp a try following the instructions on Microsoft Learn. It ended up being a challenge as those would not work on my system, and it took me a while to find the right parameters…
The Khadas Mind Premium was selected as it’s the only spare Windows system with 2.5GbE and WiFi 6 that I own and have already reviewed. You’ll notice the network tests in Windows 11 and Ubuntu 22.04 using iperf3 reveal much lower performance in the Microsoft OS as summarized in the table below.
WiFi 6 Tx
WiFi 6 Rx
2.5GbE Tx
2.5GbE Rx
WIndows 11 Home
712 Mbps
590 Mbps
700 Mbps
2.30 Gbps
Ubuntu 22.04
1.40 Gbps
991 Mbps
2.35 Gbps
2.35 Gbps
The Khadas mini PC is an outlier when it comes to 2.5GbE upload performance, but WiFi is faster in Linux in all mini PC reviews we’ve done. Since the Mind Premium review was done a while ago (August 2023), I updated Windows to the latest version and drivers and tested networking performance again with iperf3 and ntttcp in Windows 11 Home using the same command line as in the Microsoft blog post.
The first step was to install ntttcp (Linux) on UP Xtreme i11 mini PC running Ubuntu 20.04:
Only one core is used to emulate iperf3 and the V (verbose) options help a lot to troubleshoot issues. After downloading the ntttcp.exe binary to Windows we can run it immediately as a sender in a command prompt:
4/21/202410:10:47ERROR:SetupNet failed:Connect attempt failed,GetLastError:10061-No connection could be made because the target machine actively refused it.
4/21/202410:10:47PORT#: 6001
4/21/202410:10:49ERROR:SetupNet failed:Connect attempt failed,GetLastError:10061-No connection could be made because the target machine actively refused it.
But as you can see from the log above, it did not quite work as expected. It turns out that for Windows to Linux tests, we need to use the “ns” (No Sync) parameter. It’s mentioned in the Microsoft’s blog post
There is a known interoperability limitation when testing between Windows and Linux. Details can be found in this ntttcp for Linux wiki article on GitHub.
It took me a couple of hours to find out, but once I did that, I could complete the WiFi 6 Tx (upload) test:
88 MB/s or 704 Mbps, so it’s basically the same as with iperf3 even after having updated the drivers.
iperf3 has a reverse transfer option, but I could not see any such option on ntttcp. So I had to type the commands to run ntttcp.exe in receiver mode on Windows and ntttcp in sender mode on Linux. We’ll need to run CMD as administrator, open the firewall, and the networking benchmark tool with other parameters:
14:45:55INFO:1connections created in1708microseconds
14:46:55INFO:Test run completed.
14:46:55INFO:Test cycle finished.
14:46:55INFO:Thread Time(s)Throughput
14:46:55INFO:=======================
14:46:55INFO:060.002.28Gbps
14:46:55INFO:1connections tested
14:46:55INFO:##### Totals: #####
14:46:55INFO:test duration:60.00seconds
14:46:55INFO:total bytes:17068195840
14:46:55INFO:throughput:2.28Gbps
14:46:55INFO:retrans segs:54998
14:46:55INFO:cpu cores:8
14:46:55INFO:cpu speed:2000.462MHz
14:46:55INFO:user:0.46%
14:46:55INFO:system:0.78%
14:46:55INFO:idle:97.94%
14:46:55INFO:iowait:0.00%
14:46:55INFO:softirq:0.82%
14:46:55INFO:cycles/byte:1.16
14:46:55INFO:cpu busy(all):5.16%
14:46:55INFO:tcpi rtt:397us
But I still managed it. Needless to say, I did have an overly positive view of ntttcp utility so far. The only benefit I see is that we have some extra data such as CPU usage during the transfer. 2.28 Gbps is about what we would expect for a 2.5GbE connection.
I usually disconnect the Ethernet cable to test WiFi 6 with iperf3 and run the same command. But here we also need to change the IP address on both the server and client side to test it again:
14:54:58INFO:1connections created in6716microseconds
14:55:58INFO:Test run completed.
14:55:58INFO:Test cycle finished.
14:55:58INFO:1connections tested
14:55:58INFO:##### Totals: #####
14:55:58INFO:test duration:60.00seconds
14:55:58INFO:total bytes:4530110464
14:55:58INFO:throughput:604.01Mbps
14:55:58INFO:retrans segs:0
14:55:58INFO:cpu cores:8
14:55:58INFO:cpu speed:2800.000MHz
14:55:58INFO:user:0.53%
14:55:58INFO:system:0.41%
14:55:58INFO:idle:99.01%
14:55:58INFO:iowait:0.00%
14:55:58INFO:softirq:0.04%
14:55:58INFO:cycles/byte:2.93
14:55:58INFO:cpu busy(all):1.98%
604 Mbps so there’s no improvement here.
WiFi 6 Tx
WiFi 6 Rx
2.5GbE Tx
2.5GbE Rx
iperf3
551 Mbps
608 Mbps
736 Mbps
2.30 Gbps
ntttcp
785 Mbps
604 Mbps
704 Mbps
2.28 Gbps
The table above summarizes the results after I ran iperf3 again. While ntttcp is faster for WiFi 6 upload, the results are not conclusive as the other results are more or less unchanged. I suppose it only matters for high-speed networking with 10GbE or greater connections.
The tests above were done to compare ntttcp to iperf3 with similar parameters, but Microsoft says multithread and larger buffer sizes should be used to test bandwidth. Let’s try again with WiFi 6 download using 8 threads and 1024KB buffer size:
564 Mbps is slower than with only one thread and a 128KB buffer, although I reckon WiFi results can be fairly volatile.
Based on the tests done above there’s very little difference between iperf3 and ntttcp results, ntttcp Linux has not been updated for over three years, so I’m not convinced, and we’ll keep using iperf3 for the networking tests in reviews of Windows mini PCs…
Jean-Luc started CNX Software in 2010 as a part-time endeavor, before quitting his job as a software engineering manager, and starting to write daily news, and reviews full time later in 2011.
This website uses cookies to improve your experience. We'll assume you're ok with this, but if you don't like these, you can remove them Accept
Privacy & Cookies Policy
Privacy Overview
This website uses cookies to improve your experience while you navigate through the website. Out of these, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the ...
Necessary cookies are absolutely essential for the website to function properly. This category only includes cookies that ensures basic functionalities and security features of the website. These cookies do not store any personal information.
Any cookies that may not be particularly necessary for the website to function and is used specifically to collect user personal data via analytics, ads, other embedded contents are termed as non-necessary cookies. It is mandatory to procure user consent prior to running these cookies on your website.