Iperf2 vs Iperf3 – Pengukuran Kinerja Jaringan

Iperf adalah alat pengukur dan pengoptimalan kinerja jaringan.

Aplikasi iperf adalah program lintas platform yang dapat memberikan metrik kinerja jaringan standar. Iperf terdiri dari klien dan server yang dapat menghasilkan aliran data untuk menilai throughput antara dua titik akhir dalam satu atau kedua arah.

Output iperf tipikal mencakup laporan waktu yang dicap dari jumlah data yang diangkut dan throughput yang diukur.

Iperf2

Iperf2 adalah alat pengukuran responsif dan throughput jaringan yang mendukung TCP dan UDP. Salah satu tujuannya adalah untuk menjaga agar basis kode iperf berfungsi pada berbagai platform dan sistem operasi.

Ini adalah arsitektur multi-threaded yang tumbuh secara proporsional dengan jumlah CPU atau inti dalam suatu sistem yang dengan hal tersebut dapat memperoleh dan melaporkan kinerja jaringan menggunakan strategi berdampak tinggi dan rendah.

Fitur Iperf2

  • Mendukung interval laporan yang lebih kecil (100 us atau lebih besar, konfigurasikan –enable-fastsampling untuk keluaran waktu interval presisi tinggi)
  • Mendukung SO_RCVTIMEOUT untuk laporan server terlepas dari tidak ada paket
  • Dukung SO_SNDTIMEO saat mengirim sehingga penulisan soket tidak akan memblokir di luar -t atau -i
  • Mendukung SO_TIMESTAMP untuk cap waktu paket tingkat kernel
  • Mendukung latensi akhir/akhir dalam format mean/min/max/stdev (UDP) (-e diperlukan) (mengasumsikan jam klien dan server disinkronkan, misalnya dengan Precision Time Protocol ke osilator OCXO per Spectracom)
  • Mendukung aliran terbatas tingkat TCP (melalui -b) menggunakan ember token yang disederhanakan
  • Mendukung paket per detik (UDP) melalui pps sebagai unit, (mis. -b 1000pps)
  • Tampilkan PPS di laporan klien dan server (UDP) (-e diperlukan)
  • Mendukung penjadwal waktu nyata sebagai opsi baris perintah (–waktu nyata atau -z, mengasumsikan hak pengguna yang tepat)
  • Tampilkan waktu loop target di header klien awal (UDP)
  • Tambahkan dukungan lokal tautan ipv6 (mis. iperf -c fe80::d03a:d127:75d2:4112%eno1)
  • Payload ipv6 UDP default ke 1450 byte per satu frame ethernet per payload
  • Dukungan lalu lintas isochronous (melalui –isochronous) dan frame burst dengan lalu lintas bit rate (vbr) variabel dan id bingkai
  • Dukungan multicast SSM untuk v4 dan v6 menggunakan -H atau -ssm-host, mis. iperf -s -B ff1e::1 -u -V -H fc00::4
  • Histogram latensi untuk paket dan bingkai (mis. –udp-histogram=10u,200000, 0,03, 99,97)
  • Dukungan untuk pengiriman berjangka waktu mulai per –txstart-time <unix.epoch time>
  • Dukungan untuk klien yang meningkatkan ip tujuan dengan -P melalui –incr-dstip
  • Dukungan untuk memvariasikan beban yang ditawarkan menggunakan distribusi normal log di sekitar mean dan standar deviasi (per -b <mean>,<stdev>),
  • Honor -T (ttl) untuk unicast dan multicast
  • UDP menggunakan nomor urut 64 bit (meskipun masih beroperasi dengan 2.0.5 yang menggunakan nomor seq 32b.)

Sistem operasi yang didukung Iperf2

  • Linux, Windows 10, Windows 7, Windows XP, MacOS, Android dan beberapa OS set-top box.

Download Iperf2

Iperf2 Windows v2.1.8

Iperf2 Linux v2.1.8

Iperf3

Aplikasi Iperf3 adalah penulisan ulang iperf dari awal untuk membuat basis kode yang lebih kecil dan lebih sederhana.

iPerf3 adalah alat untuk mengukur bandwidth maksimum yang mungkin pada jaringan IP secara real time. Hal ini memungkinkan Anda untuk menyempurnakan berbagai pengaturan waktu, buffer, dan protokol (TCP, UDP, SCTP dengan IPv4 dan IPv6). Dan juga akan memberikan laporan bandwidth, kerugian, dan metrik lainnya untuk setiap pengujian.

iperf2

Fitur Iperf3

  • TCP dan SCTP (Ukur bandwidth, Laporkan ukuran MSS/MTU dan ukuran baca yang diamati, Dukungan untuk ukuran jendela TCP melalui buffer soket).
  • UDP (Klien dapat membuat aliran UDP dari bandwidth yang ditentukan, Mengukur kehilangan paket, Ukur delay jitter, Mampu multicast)
  • Klien dan server dapat memiliki beberapa koneksi simultan (opsi -P).
  • Server menangani beberapa koneksi, daripada berhenti setelah satu pengujian.
  • Dapat berjalan untuk waktu yang ditentukan (opsi -t), daripada sejumlah data yang akan ditransfer (opsi -n atau -k).
  • Cetak periodik, bandwidth menengah, jitter, dan laporan kerugian pada interval tertentu (opsi-i).
  • Jalankan server sebagai daemon (opsi -D)
  • Gunakan aliran representatif untuk menguji bagaimana kompresi lapisan tautan memengaruhi bandwidth yang dapat dicapai (opsi -F).
  • Sebuah server menerima satu klien secara bersamaan (iPerf3) beberapa klien secara bersamaan (iPerf2)
  • Abaikan TCP slowstart (opsi -O).
  • Tetapkan bandwidth target untuk UDP dan (baru) TCP (opsi -b).
  • Setel label aliran IPv6 (opsi -L)
  • Setel algoritma kontrol kemacetan (opsi -C)
  • Gunakan SCTP daripada TCP (–sctp option)
  • Output dalam format JSON (opsi -J).
  • Tes pembacaan disk (server: iperf3 -s / klien: iperf3 -c testhost -i1 -F nama file)
  • Tes penulisan disk (server: iperf3 -s -F nama file / klien: iperf3 -c testhost -i1)

Sistem operasi yang didukung Iperf3

  • Windows, Linux, Android, MacOS X, FreeBSD, OpenBSD, NetBSD, VxWorks, Solaris

Download Iperf3

Iperf3 Windows 64bit v3.1.3

Iperf3 Windows 32bit v3.1.3

Iperf3 Linux v3.1.3

Iperf2 vs Iperf3

FeatureIperf 2Iperf 3
Traffic types
TCP trafficYY
UDP trafficYY
SCTP trafficNY
IPv4YY
IPv6YY
Multicast traffic (including SSM)YN
TCP connect onlyYN
Layer 2 checksYN
Output options
Human formatYY
JSON outputNY
CSV (basic only)YN
Hide IP addresses in output (v4 only)YN
Client side server reportsNY
Traffic profiles
Fair queue rate limitingYY
Write rate limitingYY
Read rate limiting (TCP)YN
BurstsYY
Isochronous (video) TCP/UDPYN
Reverse rolesYY
Bidirectional trafficYY
Full duplex same socketYN
TCP bounceback w/optional working load(s)YN
Low duty cycle traffic with server side statsYN
TCP_NOTSENT_LOWAT with select() (using the –tcp-write-prefetch option)YN
TCP near congestion (experimental)YN
Metrics
ThroughputYY
Responsiveness per second (RPS)YN
UDP packets (total/lost)YY
UDP JitterYY
Packet latencies UDPYN
Frame/burst latencies TCP/UDPYN
Write-to-read latencies TCPYN
Network power (latency/throughput)YN
InP – Bytes in queues (Little’s law)YN
TCP CWNDYN
TCP retriesYY
TCP RTTYY
Send side write delay histogramsYN
UDP packets per secondYN
Latency histogramsYN
TCP connect timesYN
TCP response per intervalYN
Sum only outputYN
Other
Multi-threaded designYN
Parallel -P techniqueThreadsProcesses
Real-time schedulingYN
-t support for serverYN
TAP virtual interface support (receive only) via –tap-devYN
CPU affinityNY
Zero copyNY
IPv6 Flow labelNY
–omit option (skip first samples per time in seconds)NY
Incr dst ip option with -PYN
Incr dst ip option with -PYN
Incr dst port option with -PYN
Incr src port option with -PYN
Device or interface bindingYY
Source port bindingYN
Scheduled tx start timeYN
Delay tx start timeYN
User passwordNY
Permit keysY (TCP only)N
UDP statelessYN
Python framework (asyncio)Y (flows)N
Testing WiFi thru 100GYN/A
Scaling to 1000+ threadsYN/A

Artikel Terbaru