C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.54729 の関連記事表示

<< 0 >>
■54729  .NETリモーティング利用時に処理速度が著しく低下
□投稿者/ tick -(2010/10/30(Sat) 23:29:12)

    分類:[C#] 

    .NETリモーティングを利用してTCPを使い分散アプリケーションを作成している者です。
    本件の内容ですが、リモーティングを利用して外部(LAN)と接続されたPC間で通信を行うプログラムなのですが、
    非常に処理速度が遅くなってしまいます。もちろんLANで接続しない場合と比べた場合、速度が低下するは理解出来るのですが、
    ローカル内(1台のPC)でサーバとクライアントを同時に実行した場合と比べ21倍ほどの速度差があります。
    プログラムの内容は、各アプリケーションがクライアント機能とサーバ機能を持ったP2Pの様な構造です。
    実際のフローとしましては、

    1.[PC1のクライアント] → [PC2のサーバ]
    2.[PC2のサーバがスレッド生成/処理開始]
    3.[PC2のサーバがクライアントから渡されたデリゲートを介して] → [PC1のクライアント]

    という実装になっています。
    ローカル内(1台のPC)の状態で実験した時のフローは、

    1.[PC1のクライアント] → [PC1のサーバ]
    2.[PC1のサーバがスレッド生成/処理開始]
    3.[PC1のサーバがクライアントから渡されたデリゲートを介して] → [PC1のクライアント]

    他のリモーティングの設定としましては、

    System.Runtime.Serialization.Formatters.TypeFilterLevel.Full をListener側とClient側に設定(クライアントから渡されたデリゲートをサーバが実行するため)
    ChannelServices.RegisterChannel の ensureSecurity は false

    また、このプログラムをローカル内(1台のPC)で動かした場合はCPU使用率は80%ほどなのですがLANを介した場合アイドル状態ほどしか使用率は上がらず、非常に低速ながら処理は進んでいる模様です。
    何らかのボトルネックが発生していると考えられるのですが、探すことが出来ないでいます。御存知の方はご指摘頂ければ幸いです。
親記事 /過去ログ91より / 関連記事表示
削除チェック/

■54731  Re[1]: .NETリモーティング利用時に処理速度が著しく低下
□投稿者/ やじゅ -(2010/10/31(Sun) 13:31:19)
>
    No54729 (tick さん) に返信
    > また、このプログラムをローカル内(1台のPC)で動かした場合はCPU使用率は80%ほどなのですがLANを介した場合アイドル状態ほどしか使用率は上がらず、
    > 非常に低速ながら処理は進んでいる模様です。
    > 何らかのボトルネックが発生していると考えられるのですが、探すことが出来ないでいます。御存知の方はご指摘頂ければ幸いです。

    環境なのかソフトが原因なのか切り分けしてみてはどうでしょうか

    ・別の環境で使用してみる。
    ・アンチウィルス系のソフトやファイヤーウォールを切ってみる。
    ・別の.NETリモーティングソフトを動かしてみる。
    ・TCP Monitor Plus や Microsoft Network Monitor などのソフトを使いTCPを監視してみる。
     TCP Monitor Plus:http://hp.vector.co.jp/authors/VA032928/index.html#tcpmon
     Microsoft Network Monitor:http://www.forest.impress.co.jp/article/2008/09/19/msnetworkmonitor32.html
記事No.54729 のレス /過去ログ91より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -