を使用してクライアントとホスト間の速度をテストしていますiperf
。私のアプリケーションでは、およそ 5KHz で 2 バイトの UDP フレームを送信できる必要があります。
通常の UDP 速度テストを実行すると、簡単に 10Mb/s を取得できます。
$iperf -uVc some_ip -b 10M
Interval Transfer Bandwidth Dropped/Sent
0.0-10.0 sec 11.9 MBytes 10.0Mbit/sec 0 / 8504 (0%)
次に、2B を 5Hz (80Kb/s に相当) で送信してアプリケーションをミラーリングしようとすると、次のようになります。
$iperf -l 2 -uVc some_ip -b 80K
サーバー側は、パケットが通過しなかったと言っていますが、これは、カウンターまたはiperf
パケットを追跡するために使用するものが 2B ペイロード内に収まらないためです。これは理にかなっていますか?
一般的な経験則として、多くの小さなパケットを送信することと、大きなパケットを送信しないことのどちらが悪いでしょうか? 大きなデータグラムを「パック」するのを待つことと、取得したらすぐに2Bのデータを即座に送信することとのトレードオフを説明する文献を指摘できる人はいますか?
さらに明確にするために、多くの小さなパケット (オーバーヘッドを含め、パケットは約 60B しかありません) を送信した場合と、少数ではあるが大きなパケットを送信した場合に支払うペナルティに関心があります。これまでの私のテストでは、パケット ドロップは明らかに帯域幅の使用と相関しておらず、むしろ直感に反するパケット数と相関しています。
編集:
私はこれを最も単純なクライアント - サーバーのセットアップで行っています。ローカル ネットワークに接続された 2 台の Linux PC 間で、その間にイーサネット スイッチがあるネットワーク上の唯一のインターフェイスです。