ネットワークファイルのコピー速度が波を形成するのはなぜですか?


16

Windows 10にアップグレードすると、ファイルをコピーするときにこの素敵なグラフが表示されます。

単一の大きなファイルをコピーすると、速度は常にこの合理的に一貫した波形になります。何が原因ですか?

接続は

My PC <- cable -> gigabit switch <- cable -> Netgear ReadyNAS

ファイルはSMBを介してコピーされています。このグラフは、1分程度のコピーを示しています。

Windows 10からのコピー速度のグラフ

ここには問題はありません。物事の仕組みを理解したいだけです。


1
ReadyNASディスク構成に関する詳細が役立ちます。3つのドライブでRAID 5を使用していますか?各ドライブの書き込み速度はどのくらいですか?各ドライブのバッファとは何ですか?また、ReadyNASが使用するキャッシュはありますか?転送速度が異なるかどうかを確認するために、TeraCopyなどの他のツールを試しましたか?そうでない場合、特に書き込み速度が良くない場合(例:Seagate Barracuda)、ディスクキャッシュの書き込みにボトルネックがある可能性があります。

NASを時々使用している可能性のある他のすべてのプロセスを閉じましたか?
アルジャン

回答:


6

短い答え:書き込みキャッシュ

TL; DR:最初に、単一の大きなファイルをコピーするときのオーバーヘッドは、多くの小さなファイルと比較してはるかに少ないです。つまり、PCとNASは、ファイルの検索、ファイルテーブルおよびファイルシステムのメタデータの更新に多くの時間を「浪費」していません。これは、スループットが大幅に向上することも意味し、セットアップの帯域幅のボトルネックの一部が明らかになる可能性があります。

帯域幅グラフの山と谷はかなり規則的な間隔で発生しているようで、単一の大きなファイル(最大帯域幅、最小オーバーヘッド)をコピーしているという事実を考えると、バッファリング/キャッシュの効果が見られると思います。

おそらく、NASにデータをディスクに書き込むよりも速い速度でデータを送信しているようです。書き込みキャッシュ/バッファのおかげで、それはより速いレート(グラフのピーク)で受信できますが、ディスクにコミットせずにデータを受信し続けることはできません。

最終的に、バッファーはいっぱいになり、ディスクに書き込む必要があります。一方、NASはデータを格納する場所がないため、以前ほど高速にデータを受信できません(バッファがいっぱいで、ディスクが低速です)。これは、グラフの谷を取得する場所です。

Windowsはスループットグラフを平滑化しているようです。より正確なグラフ(パフォーマンスモニターなど)を使用すると、間隔と転送バイトを分析することで、実際に書き込みバッファーサイズを推定できます。

ピークと谷が完全に均一な間隔で発生しない理由は、おそらくファイルをコピーしている間、PC、NAS、またはその両方が「何か他のこと」をしているためです。


バッファーがいっぱいになると、突然のスパイク(約0まで)のある水平線が生成されませんか?
アルジャン

ファイルコピーグラフは、おそらく視覚的な魅力のために平滑化されているようです。PerfMonは、おそらくより正確なグラフを作成します。また、ディスクへのフラッシュに使用されるアルゴリズムにも依存します。たとえば、すべてがディスクに書き込まれるまでデータの受信を停止するか、データの受信を低速で制限するため、新しいデータを受信するよりも高速にディスクに書き込むことができます。
抽象化

17

さらなる調査をせずに正式に回答することは困難です。時間スケールとプロトコルで質問を更新していただきありがとうございます。

通常のTCP「ホタテ」ができます。TCPは、パケット損失が発生するまで可能な限り高速になります。その後、少し後退し、再びランプアップします。したがって、「頭を天井にぶつけて」います。これは、輻輳を悪化させることなく、利用可能な帯域幅を最大化する方法です。私は通常TCPTraceグラフでTCPホタテ貝を見るが、これはこのグラフとは少し異なる。この種のグラフでは、もう少し鋸歯状に見えると思いますが、このグラフではある程度の平滑化が行われている可能性があります。そして今、私はそれについて考えると、TCP帆立貝はこのグラフが示すように見えるよりもはるかに小さなタイムスケールになります。

また、リモートファイルシステムプロトコル(SMB)が一度に1つのチャンクでファイルを読み取り、1つのチャンクの読み取りが完了し、次のチャンクが要求されている場合もあります。


詳細の欠如について申し訳ありませんが、人々が何を知る必要があるのか​​わかりませんでした。私はsmbを使用しており、そのグラフは約1分間の期間をカバーしています
-Gricey

4
@Gricey:コメントしないでください:質問を修正してください!!
モニカーとの軽さのレース

-1不要なnitpicking
Mehrdad

@LightnessRacesinOrbitの修正
-Gricey

1
@Gricey詳細についてはとてもうるさいことをおaびします。私は、人々が必要とする詳細を知らなければ、たくさんのものを文書化するのは難しいという感情を理解しています。支援する人々がイライラしないように十分に文書化することと、重要ではないものを文書化するのに時間を浪費しているように感じることとのバランスは難しい。
-Spiff

0

Microsoftはこの機能をWindows 8のプログレスバーに導入したと思います

左から右のショーの割合で進行アップダウン運動ショーMB /秒の転送速度を

転送速度は、メディア(BUSまたはネットワーク)の速度、ファイルの数とサイズ、ファイルシステムとリソースの可用性などによって決まります。

また、ファイル転送中に、多くのメタデータの読み取り/書き込みが行われます。

このメタデータの読み取り/書き込みのオーバーヘッドが削減され、他のリソースが同じレートで使用されているため、合理的に一貫した波が見られます。時々の低下は、パケット損失、次のチャンク読み取り、リソースポーリングなどのイベントである可能性があります。

さらに明確にするために、ここでさらに読みます


3
これは本当に質問に答えません。
モニカーとの軽さのレース
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.