サーバー側コード (WCF) で TransactionScope クラスを使用すると、パフォーマンスの問題が発生します。
私のコードはクライアントからリクエストを受け取り、TransactionScope を作成し、短い操作 (通常は最大 100 ミリ秒) を実行します。
私のサーバー側コードをシミュレートする以下の添付コードを参照してください。100人以上の同時ユーザーがいる場合、1秒以上かかるという問題!!! 新しい TransactionScope を作成します (GetTransaction() メソッドを参照)。
同時ユーザー数が 200 に達すると、TransactionAborted がスローされます。
あなたはなにか考えはありますか?
class Program
{
private static ConcurrentQueue<double> m_Queue = new ConcurrentQueue<double>();
static void Main(string[] args)
{
Console.WriteLine("Press any key to start ...");
Console.ReadKey();
for (int i = 0; i < 100; i++)
{
Thread t = new Thread(new ThreadStart(Method));
t.IsBackground = true;
t.Start();
}
Thread.Sleep(2000);
Console.WriteLine("Max {0}, Min {1}, Avg {2}, Total {3}", m_Queue.Max(), m_Queue.Min(), m_Queue.Average(), m_Queue.Count);
Console.ReadKey();
}
private static void Method()
{
using (TransactionScope scope = GetTransaction())
{
Thread.Sleep(100);
scope.Complete();
}
}
public static TransactionScope GetTransaction()
{
var start = DateTime.Now;
TransactionOptions options = new TransactionOptions();
options.IsolationLevel = IsolationLevel.ReadCommitted;
var t = new TransactionScope(TransactionScopeOption.Required, options);
// Log creation time
m_Queue.Enqueue((DateTime.Now.Subtract(start)).TotalMilliseconds);
return t;
}
}