非常に長いループを含むメソッドでテスト サービスを作成しました。タイムアウト トランザクションが発生すると、メソッドの実行がフラッシュされることを期待していましたが、そうではありません。クライアントはタイムアウトしますが、処理はサーバーで続行されます。
それを止める方法はありますか?メソッドコードを変更せずに?
次に例を示します。この例では、キュー バインディングを使用して QueueRequest メソッドを呼び出し、10 秒後にトランザクションが中止されます。この時点で再試行が発生し、同じ問題が発生します。数回再試行した後、メッセージが有害でドロップされた場合でも、サーバーは 100% の CPU 作業を行い、複数のスレッド/インスタンスでループを実行しようとします。
// NOTE: If you change the class name "Service1" here, you must also update the reference to "Service1" in App.config.
[ServiceBehavior(InstanceContextMode=InstanceContextMode.PerCall,
TransactionTimeout="00:00:10",
ReleaseServiceInstanceOnTransactionComplete=true)]
[ErrorHandlingBehaviorAttribute]
public class Service1 : IQueueService
{
public Service1()
{
Trace.WriteLine("Creating an instance on thread " + Thread.CurrentThread.ManagedThreadId.ToString());
}
~Service1()
{
Trace.WriteLine("Destroying an instance on thread " + Thread.CurrentThread.ManagedThreadId.ToString());
}
[OperationBehavior(TransactionScopeRequired = true, TransactionAutoComplete = true)]
public void QueueRequest(string message)
{
int id = Thread.CurrentThread.ManagedThreadId;
Trace.WriteLine("Got Message on thread " + id.ToString());
for (int i = 0; i < 1000000; i++)
{
Trace.WriteLine("Processing " + i.ToString() + " Thread ID " + id.ToString());
Thread.Sleep(1000);
}
}
}