1. ホーム
  2. c#

[解決済み】WSACancelBlockingCallの例外について

2022-02-14 08:26:21

質問内容

私のコードから奇妙な例外がスローされ、長い間私を悩ませています。

System.Net.Sockets.SocketException: A blocking operation was interrupted by a call to WSACancelBlockingCall
   at System.Net.Sockets.Socket.Accept()
   at System.Net.Sockets.TcpListener.AcceptTcpClient()

MSDNはこれに関してあまり役に立ちません。 http://msdn.microsoft.com/en-us/library/ms741547(VS.85).aspx このトラブルシューティングをどのように始めたらいいのかさえわかりません。1日に4、5回しか発生しませんし、テスト環境では一度も発生しません。本番サイトでのみ、しかもすべての本番サイトでです。

この例外について質問している投稿はたくさんありますが、何が原因なのか、どのように対処または防止すればよいのか、実際に明確な回答はありません。

コードは別のバックグラウンドスレッドで実行され、メソッドは :

public virtual void Startup()
    {
     TcpListener serverSocket= new TcpListener(new IPEndPoint(bindAddress, port));    
        serverSocket.Start();

それから、新しい接続をすべてジョブとして別のスレッドプールに置くループを実行します。アプリのアーキテクチャの関係でもっと複雑になりますが、基本的には

   while (( socket = serverSocket.AcceptTcpClient()) !=null) //Funny exception here
    {
         connectionHandler = new ConnectionHandler(socket, mappingStrategy);
         pool.AddJob(connectionHandler);
    }
  }

そこから pool は独自のスレッドを持っていて、それぞれのジョブを別々に処理します。

私の理解では、AcceptTcpClient()はブロッキング・コールであり、何らかの方法でwinsockがスレッドにブロッキングを止めて実行を続けるように言っているのだと思いますが、なぜでしょうか?そして私はどうすればいいのでしょうか?ただ例外をキャッチして無視すればいいのでしょうか?


まあ、他のスレッドがソケットを閉じているのだと思いますが、私のコードからではないことは確かです。 私が知りたいのは、このソケットが接続中のクライアント(ソケットの反対側)によって閉じられたのか、それとも私のサーバーによって閉じられたのか、ということです。なぜなら、今のところ、この例外が発生するたびに、私のリスニングポートをシャットダウンし、事実上私のサービスを閉じているからです。もしこれが遠隔地から行われるのであれば、大きな問題です。

あるいは、これは単にIISサーバーが私のアプリケーションをシャットダウンして、バックグラウンドのスレッドとブロックメソッドをすべてキャンセルしているだけなのでしょうか?

解決方法は?

他のスレッドからserverSocketがクローズされている可能性はないでしょうか? その場合、この例外が発生します。