private async void StartTasks_Click(object sender, RoutedEventArgs e) { await Task.WhenAll(GetSomeData()); lblResult.Text = "Got data?";}private async Task GetSomeData(){ System.Net.ServicePointManager.DefaultConnectionLimit = 16; ServiceClient _proxy = new ServiceClient(); //*** the wcf proxy service methods just sleep for 5 seconds. var t1 = _wcfProxy.A(); var t2 = _wcfProxy.A(); var t3 = _wcfProxy.A(); var t4 = _wcfProxy.A(); await Task.WhenAll(t1,t2,t3,t4);}當(dāng)我點擊我的按鈕時,我希望我的標(biāo)簽文本被設(shè)置5 seconds(因為我的 WCF 方法調(diào)用只是休眠 5 秒)。嗯,它需要10 seconds。現(xiàn)在,當(dāng)我只進行三個服務(wù)調(diào)用而不是四個時,標(biāo)簽設(shè)置在5 seconds.當(dāng)我在進行所有四個調(diào)用時查看性能監(jiān)視器中的調(diào)用計數(shù)時,我只看到 3 個進入,然后在前三個完成后其他 1 個進入。
1 回答

夢里花落0921
TA貢獻1772條經(jīng)驗 獲得超6個贊
總而言之,您的 WCF 服務(wù)的默認(rèn) IOCP 線程池似乎正在耗盡(很難說出原因;請檢查ThreadPool.GetMinThreads
和ThreadPool.GetAvailableThreads
)。因此,最有可能的是,當(dāng)您使用Thread.Sleep
while services 阻塞 WCF 線程時_wcfProxy.A()
,沒有另一個線程可用于 serve _wcfProxy.B()
,因此B
請求會排隊等待,直到A
完成。
嘗試實現(xiàn)WorkerThreadPoolSynchronizer
并WorkerThreadPoolBehaviorAttribute
按照該文章中的描述,應(yīng)用[WorkerThreadPoolBehavior]
到A
andB
并查看是否可以解決問題。
- 1 回答
- 0 關(guān)注
- 178 瀏覽
添加回答
舉報
0/150
提交
取消