Asynchronous Operation in WCF

299
15 июня 2017, 03:29

Мне нужно выполнить background операцию, которая занимает много времени в моем WCF-сервисе. Сервис не должен быть заблокирован во время выполнения этой операции. Вызов операции происходит из контроллера. Server Side:

[ServiceContract]
public interface IServiceContract
{
    [OperationContract]
    System.Threading.Tasks.Task<string> GetMessages(int sleep);
}
public class HelloService : IServiceContract
{
    public async System.Threading.Tasks.Task<string> GetMessages(int sleep)
    {
        var task = System.Threading.Tasks.Task.Factory.StartNew(() =>
        {
            Thread.Sleep(sleep);
            return "Return from Server after: " + sleep;
        });
        return await task.ConfigureAwait(false);
    }
}

Client side:

public partial class HelloServiceClient : ClientBase<IServiceContract>,
                                          IServiceContract {
   public System.Threading.Tasks.Task<string> GetMessages(int sleep)
   {
       return Channel.GetMessages(sleep);
   }

Использование в контроллере:

    public async System.Threading.Tasks.Task<string> GetResult(int sleep)
    {
       var client = DAACommunicationServiceHelper.CreateClient();
       SystemLogManager.Current.Write("Start GetResult: " + sleep);
       var result = await client.GetMessages(sleep);
       SystemLogManager.Current.Write("GetResult = " + result);
       SystemLogManager.Current.Write("End GetResult: " + sleep);
       return result;
    }

После этого я отправила 2 запроса:

POST https://localhost:44374/Services/Maintenance.asmx/GetResult HTTP/1.1
{"sleep":1000}

и сразу

POST https://localhost:44374/Services/Maintenance.asmx/GetResult HTTP/1.1
{"sleep":1}

Я ожидала что запрос "sleep":1 выполниться быстрее, но WCF-сервис был заблокирован пока не выполнился запрос "sleep":10000.

Вот что в логах:

2017-06-14 11:25:16.1684 INFO Start GetResult: 10000
2017-06-14 11:25:19.3156 INFO Start GetResult: 1
2017-06-14 11:25:26.1802 INFO GetResult = Return from Server after: 10000
2017-06-14 11:25:26.1802 INFO End GetResult: 10000
2017-06-14 11:25:26.1802 INFO GetResult = Return from Server after: 1
2017-06-14 11:25:26.1802 INFO End GetResult: 1

UPD: Почему WCF-сервис был заблокирован пока не выполнился запрос "sleep":10000? Мне нужно чтобы WCF-сервис выполнял операцию асинхронно и запросы возвращались по мере выполнения. В логах я рассчитывала увидеть такое:

2017-06-14 11:25:16.1684 INFO Start GetResult: 10000
2017-06-14 11:25:19.3156 INFO Start GetResult: 1
2017-06-14 11:25:26.1802 INFO GetResult = Return from Server after: 1
2017-06-14 11:25:26.1802 INFO End GetResult: 1
2017-06-14 11:25:26.1802 INFO GetResult = Return from Server after: 10000
2017-06-14 11:25:26.1802 INFO End GetResult: 10000
READ ALSO
что значит условие продолжения цикла ;i &lt; width&mdash; size; опечатка?

что значит условие продолжения цикла ;i < width— size; опечатка?

Язык C#Кусок кода из книги Паласиоса про исскус

193
Как сделать так чтобы пуля летела вперед [требует правки]

Как сделать так чтобы пуля летела вперед [требует правки]

Какая команда нужна чтобы gameobject создавался и летел вперед?

245
возобновление загрузки C#

возобновление загрузки C#

Не могу сообразить как сделать возобновление загрузки при потере соединения интернета

184
Доступ к localStorage для 2 скриптов Chrome Extension

Доступ к localStorage для 2 скриптов Chrome Extension

Столкнулся с такой проблемой

311